Доступ к хранилищу запрещен. доступ через ключ развертывания доступен только для чтения
после успешного клонирования моего РЕПО из heroku и добавления еще одного удаленного
1/ git clone git@heroku.com:[APP].git
2/ git remote add bitbucket ssh://git@bitbucket.org/[ACCOUNT]/[REPO].git
3/ git push bitbucket master
Я все еще получаю эту ошибку после запуска строки (3) или использования SourceTree
conq: repository access denied. access via a deployment key is read-only.
во-первых, я не понимаю, что означает это сообщение на практике. И это позор.
Я создал пару ключей ssh и добавил в heroku:
ssh-keygen -t rsa
heroku keys:add ./id_rsa.pub
Я также добавил свой ключ в раздел ключей развертывания в BitBucket. Но я чего-то не хватает. Этот вопрос не из лени я читал различные документы, включая руководства BitBuckets. Но это все равно не обойти этот вопрос.
этот пост связан с могу ли я импортировать РЕПО heroku Git в bitbuket? и как?
ДОПОЛНИТЕЛЬНЫЕ ФАКТЫ:
ssh -T hg@bitbucket.org
conq: authenticated via a deploy key.
You can use git or hg to connect to Bitbucket. Shell access is disabled.
$ ssh -v git@bitbucket.org
OpenSSH_5.6p1, OpenSSL 0.9.8r 8 Feb 2011
debug1: Reading configuration data /Users/joel/.ssh/config
debug1: Applying options for bitbucket.org
debug1: Reading configuration data /etc/ssh_config
debug1: Applying options for *
debug1: Connecting to bitbucket.org [207.223.240.181] port 22.
debug1: Connection established.
debug1: identity file /Users/joel/.ssh/id_rsa type 1
debug1: identity file /Users/joel/.ssh/id_rsa-cert type -1
debug1: Remote protocol version 2.0, remote software version OpenSSH_5.3
debug1: match: OpenSSH_5.3 pat OpenSSH*
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_5.6
debug1: SSH2_MSG_KEXINIT sent
debug1: SSH2_MSG_KEXINIT received
debug1: kex: server->client aes128-ctr hmac-md5 none
debug1: kex: client->server aes128-ctr hmac-md5 none
debug1: SSH2_MSG_KEX_DH_GEX_REQUEST(1024<1024<8192) sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_GROUP
debug1: SSH2_MSG_KEX_DH_GEX_INIT sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_REPLY
debug1: Host 'bitbucket.org' is known and matches the RSA host key.
debug1: Found key in /Users/joel/.ssh/known_hosts:5
debug1: ssh_rsa_verify: signature correct
debug1: SSH2_MSG_NEWKEYS sent
debug1: expecting SSH2_MSG_NEWKEYS
debug1: SSH2_MSG_NEWKEYS received
debug1: Roaming not allowed by server
debug1: SSH2_MSG_SERVICE_REQUEST sent
debug1: SSH2_MSG_SERVICE_ACCEPT received
debug1: Authentications that can continue: publickey
debug1: Next authentication method: publickey
debug1: Offering RSA public key: /Users/joel/.ssh/id_rsa
debug1: Remote: Forced command: conq deploykey:13907
debug1: Remote: Port forwarding disabled.
debug1: Remote: X11 forwarding disabled.
debug1: Remote: Agent forwarding disabled.
debug1: Remote: Pty allocation disabled.
debug1: Server accepts key: pkalg ssh-rsa blen 279
debug1: read PEM private key done: type RSA
debug1: Remote: Forced command: conq deploykey:13907
debug1: Remote: Port forwarding disabled.
debug1: Remote: X11 forwarding disabled.
debug1: Remote: Agent forwarding disabled.
debug1: Remote: Pty allocation disabled.
debug1: Authentication succeeded (publickey).
Authenticated to bitbucket.org ([207.223.240.181]:22).
debug1: channel 0: new [client-session]
debug1: Requesting no-more-sessions@openssh.com
debug1: Entering interactive session.
debug1: Sending environment.
debug1: Sending env LC_CTYPE = UTF-8
PTY allocation request failed on channel 0
похоже, все в порядке.
16 ответов
первая путаница с моей стороны была о том, где именно установить SSH-ключей в BitBucket.
Я новичок в BitBucket, и я устанавливал Ключевые Развертывания что дает чтение только.
поэтому убедитесь, что вы настраиваете rsa pub key
в своем Настройки Учетной Записи BitBucket.
щелкните свой аватар BitBucket и выберите Управление учетной записью. Там вы сможете установить SSH Ключи!--3-->.
Я просто удалены Ключевые Развертывания, мне пока ничего не нужно. И это сработало!--4-->
теперь опция SSH находится под настройками безопасности
нажмите свой аватар -- > настройки Bitbucket -- > SSH ключ --> добавить ключ
вставьте открытый ключ
ключи развертывания доступны только для чтения. Чтобы включить доступ на запись, вам нужно:
удалите этот ключ развертывания из настроек репозитория. Вы все равно не сможете написать в это РЕПО с этим ключом.
перейдите в "Аватар - > настройки - > ключи SSH" и добавьте тот же ключ
теперь попробуйте нажать, чтобы удалить ветку
вы могли писать в репозитории раньше, но это изменение в BitBucket, где вы больше не можете писать с помощью ключа развертывания.
"ключ развертывания" предназначен только для доступа только для чтения. Следовать-хороший способ пройти через это.
- создать и SSH ключ и добавить его в bitbucket (аватар пользователя -> настройка Bitbucket-> SSH ключи)
- ~/.СШ/если вы
- ssh-add-D (удалить ключи, загруженные в SSH agent)
- ssh-add ~/.ssh / your_private_key_for_bitbucket
- ssh git@bitbucket.org -Tv (убедитесь, что ваш ключ используется для подключения к тут Bitbucket)
- git нажмите "удаленное имя ""название филиала"
сначала необходимо удалить ключ развертывания, если вы собираетесь добавить тот же ключ в разделе Управление SSH-ключом учетной записи.
TLDR: ssh-add ~/.ssh / yourkey
Я только что проработал эту проблему.
и ни один из других ответов не помог.
У меня была ./ssh / config со всеми нужными материалами, а также более ранним репозиторием, работающим нормально (та же учетная запись bitbucket, тот же ключ). Затем я создал deploy_key, а после этого создал новый репозиторий.
после этого не удалось клонировать новый РЕПО.
Я хотел бы знать, как / почему ssh agent испортил это, но добавление ключа решило его. Я имею в виду добавление ключа в мой локальный Ubuntu, а не в Bitbucket admin. Команда просто
~/.ssh$ ssh-add myregualrkey
надеюсь, это кому-то поможет.
это произошло, когда я пытался использовать ключ развертывания, потому что это именно то, что я хотел.
Я мог бы подключиться через ssh -T git@bitbucket.org
и это скажет мне, что у меня есть доступ к чтению репозитория, который я хотел, но git clone
потерпит неудачу.
очистка ~/.ssh/known_hosts
, создание нового ключа через ssh-keygen
, добавив этот новый ключ к bitbucket, и повторная попытка исправила его для меня.
вы должны добавить свой ключ в свой профиль и не в определенный репозиторий. следить за этим: https://community.atlassian.com/t5/Bitbucket-questions/How-do-I-add-an-SSH-key-as-opposed-to-a-deployment-keys/qaq-p/413373
недавно я столкнулся с той же проблемой. Я получил следующую ошибку:
доступ к репозиторию отказано. доступ через ключ развертывания доступен только для чтения.
вы можете иметь два вида ключей SSH:
- для всей вашей учетной записи которая будет работать для всех репозиториев
- на ключ SSH репозитория который может использоваться только для этого конкретного репозитория.
Я просто удалил свой репозиторий SSH ключ и добавил новый SSH ключ к моей учетной записи, и он работал хорошо.
надеюсь, это кому-то поможет. Ура!--1-->
действия:
-
создать ssh ключи на исходном сервере
ssh-keygen
Cat и скопируйте id_rsa.паб расположен под ~./СШ каталог
- перейдите в Bitbucket, если вы уже установили ключи доступа для репозитория(ов), затем удалите существующие открытые ключи
- перейдите к аватару Bitbucket> настройки Bitbucket> ключи SSH (в разделе Безопасность, левая панель)> нажмите "Добавить ключи"> вставьте общедоступный ключ.
-
проверьте, работает ли он, выполнив команду ниже на исходном сервере
git remote show origin
-
для выборки и push с исходного сервера, если протокол "https", то вы должны изменить его на "git + ssh", выполнив команду ниже
git remote set-url origin git+ssh://<bitbucketaccount>@bitbucket.org/<accountname>/repo.git
проверьте, можете ли вы нажать на репо.
готово!
Я хотел бы еще раз подчеркнуть следующее:
- возможно, вы добавили ключ SSH в хранилище (например, ExampleRepo), но это не там, где ключ SSH идет.
- Он предназначен для перехода в ВАШ ПРОФИЛЬ. Это маленький аватар в левом нижнем углу экрана. здесь вы найдете разные место для размещения ключей SSH (под безопасностью) > затем вы добавляете ключ здесь вместо.
- Если вы случайно поместили свой SSH-ключ в репозиторий (в отличие от вашей учетной записи), удалите его в репозитории.
мне потребовались века, чтобы понять, почему-то даже после прочтения ответов здесь он не щелкнул.
У меня была та же проблема, что и у Кабира Зарина. Решение состояло в том, чтобы клонировать РЕПО через SSH, а не использовать URL https. так вот что помогло мне и, надеюсь, другим:
git clone git@bitbucket.org:{accountName}/{repoName}.git
все, что вам нужно - добавить еще один ключ и использовать его.
Как я нашел первый ключ-всегда ключ развертывания.
двухшаговый процесс, который нужно мочь нажать тяга
Шаг 1: Создайте ssh-ключ (открытый и закрытый) на mac
Шаг 2: Поместите закрытый ключ в mac и открытый ключ на веб-сайте git
ниже приведены подробные шаги для пользователей mac
Шаг 1: генерация ключей
- (убедитесь, что у вас установлен git)https://git-scm.com/download/mac
- откройте терминал и введите
ssh-keygen
это предложит вам ввести место хранения для ключа, вы можете ввести/Users/[machinename]/.ssh/[keyname]
- далее он попросит парольную фразу, Вы можете либо оставить его пустым, нажав enter или введите ключевое слово, которое будет введено снова в следующем приглашении
- это создаст для вас два ключа, закрытый и открытый, с именем [keyname] и [keyname].паб
Шаг 2: нажатие клавиш в соответствующие места[mac и удаленные учетные записи i.e Github, bitbucket, gitlab и т. д ]
- тип
ssh-add -K ~/.ssh/[keyname]
в терминале, чтобы добавить свой закрытый ключ к mac - тип
pbcopy < ~/.ssh/[keyname].pub
скопировать публичный ключ в буфер обмена - откройте Настройки учетной записи на вашем соответствующем веб-сайте git и перейдите к add key, там вставьте открытый ключ, скопированный выше
готово, теперь вы можете нажать pull.
для этой ошибки: conq: доступ к репозиторию запрещен. доступ через ключ развертывания доступен только для чтения.
Я меняю имя своего ключа, пример
cd /home/try/.ssh/
mv try id_rsa
mv try.pub id_rsa.pub
Я работаю над своим ключом на bitbucket