Доступ к репозиторию запрещен. доступ через ключ развертывания доступен только для чтения
после успешного клонирования моего РЕПО от 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 repo в 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 Ключи.
Я просто удалены Ключевые Развертывания, мне сейчас ничего не нужно. И это сработало
теперь опция SSH находится в настройках безопасности
нажмите на свой аватар -- > настройки Bitbucket -- > SSH Key --> добавить ключ
вставьте свой публичный ключ
ключи развертывания доступны только для чтения. Для включения доступа на запись необходимо:
удалите этот ключ развертывания из настроек репозитория. Вы все равно не сможете написать в это РЕПО с этим ключом.
перейдите в раздел "Аватар - > настройки - > ключи SSH" и добавьте тот же ключ
теперь попробуйте нажать, чтобы удалить ветку
раньше вы могли писать в репозитории, но это изменение BitBucket, где вы больше не можете писать с помощью ключа развертывания.
'ключ развертывания' предназначен только для доступа только для чтения. Следующий хороший способ, чтобы работать через это.
- создать и SSH ключ и добавить его в bitbucket (аватар пользователя -> настройка Bitbucket-> SSH ключи)
- ~/.ssh / known_hosts
- ssh-add-D (удалить ключи, загруженные в SSH agent)
- ssh-add ~/.ssh / your_private_key_for_bitbucket
- ssh git@bitbucket.org -телевизор (убедитесь, что ваш ключ используется для подключения bitbucket)
- git push 'remote name ''имя филиала'
вы должны сначала удалить ключ развертывания, если вы собираетесь добавить тот же ключ в разделе Управление учетной записью SSH Key.
TLDR: ssh-add ~/.ssh / yourkey
Я только что проработал эту проблему.
и ни один из других ответов не помог.
У меня был a ./ssh / config со всеми нужными вещами, также более ранний репозиторий работает нормально (та же учетная запись bitbucket, тот же ключ). Затем я сгенерировал deploy_key, а после этого создал новый репозиторий.
после этого не удалось клонировать новый РЕПО.
Я хотел бы знать, как / почему ssh агент испортил это, но добавление ключа решило ее. Я имею в виду добавление ключа в мой локальный 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 ключ к моей учетной записи, и он работал хорошо.
Я надеюсь, что это поможет кому-то. Ура
действия:
создать ssh ключи на исходном сервере
ssh-keygen
Cat и скопируйте id_rsa.паб расположен под ~./СШ каталог
- перейдите в Bitbucket, если вы уже установили ключи доступа для репозитория(ов), а затем удалите существующий открытый ключ(ы)
- перейдите в Bitbucket avatar> Bitbucket settings> SSH Keys (в разделе Безопасность, левая панель)> нажмите "Добавить ключи" > вставьте public ключ.
проверьте, работает ли он, выполнив команду ниже на исходном сервере
git remote show origin
для fetch и push с исходного сервера, если протокол "https", то вы должны изменить его на "git + ssh", выполнив команду ниже
git remote set-url origin git+ssh://<bitbucketaccount>@bitbucket.org/<accountname>/repo.git
проверьте, если вы можете сделать push в репозиторий.
готово!
Я хотел бы еще раз подчеркнуть следующее:
- возможно, вы добавили ключ SSH в хранилище (например, ExampleRepo), но это не там, где ключ SSH идет.
- он должен войти в ВАШ ПРОФИЛЬ. Это маленький аватар в левом нижнем углу экрана. здесь вы найдете разные место для размещения ключей SSH (под защитой) > затем вы добавляете ключ здесь вместо.
- Если вы случайно поместили свой SSH-ключ в репозиторий (в отличие от вашей учетной записи), удалите его в репозитории.
мне потребовались годы, чтобы понять, как-то даже после прочтения ответов здесь он не щелкнул.
У меня была та же проблема, что и у Кабира Зарина. Решение состояло в том, чтобы клонировать РЕПО через SSH, а не использовать URL-адрес https. так что это то, что помогло мне, и, надеюсь, другие:
git clone git@bitbucket.org:{accountName}/{repoName}.git
все, что вам нужно - добавить еще один ключ и использовать его.
Как я нашел первый ключ-всегда ключ развертывания.
иногда это не работает, потому что вы вручную устанавливаете другой ключ для bitbucket в
~/.ssh/config
.
двухэтапный процесс, чтобы иметь возможность толкать тянуть
Шаг 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 и удаленные учетные записи, т. е. Github, bitbucket, gitlab и т. д ]
- тип
ssh-add -K ~/.ssh/[keyname]
в терминале, чтобы добавить свой закрытый ключ к mac- тип
pbcopy < ~/.ssh/[keyname].pub
чтобы скопировать открытый ключ в буфер обмена- откройте Настройки учетной записи на соответствующем веб-сайте git и перейдите к add key, там вставьте открытый ключ, скопированный выше
готово, теперь вы можете двухтактный.