Вы должны загрузить свой открытый ключ в Heroku:
heroku keys:add ~/.ssh/id_rsa.pub
Если у вас нет открытого ключа, Heroku предложит вам добавить его автоматически, что работает без проблем. Просто используйте:
heroku keys:add
Чтобы очистить все ваши предыдущие ключи, сделайте:
heroku keys:clear
Чтобы отобразить все существующие ключи, выполните следующие действия:
heroku keys
РЕДАКТИРОВАТЬ:
Вышеупомянутое, похоже, не сработало для меня. Я испортил переменную окружения HOME
, поэтому SSH искал ключи в неправильном каталоге.
Чтобы убедиться, что SSH проверяет ключ в правильном каталоге, выполните:
ssh -vT [email protected]
Что отобразит следующие (Образцы) строки
OpenSSH_4.6p1, OpenSSL 0.9.8e 23 Feb 2007
debug1: Connecting to heroku.com [50.19.85.156] port 22.
debug1: Connection established.
debug1: identity file /c/Wrong/Directory/.ssh/identity type -1
debug1: identity file /c/Wrong/Directory/.ssh/id_rsa type -1
debug1: identity file /c/Wrong/Directory/.ssh/id_dsa type -1
debug1: Remote protocol version 2.0, remote software version Twisted
debug1: no match: Twisted
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_4.6
debug1: SSH2_MSG_KEXINIT sent
debug1: SSH2_MSG_KEXINIT received
debug1: kex: server->client aes128-cbc hmac-md5 none
debug1: kex: client->server aes128-cbc hmac-md5 none
debug1: sending SSH2_MSG_KEXDH_INIT
debug1: expecting SSH2_MSG_KEXDH_REPLY
debug1: Host 'heroku.com' is known and matches the RSA host key.
debug1: Found key in /c/Wrong/Directory/.ssh/known_hosts:1
debug1: ssh_rsa_verify: signature correct
debug1: SSH2_MSG_NEWKEYS sent
debug1: expecting SSH2_MSG_NEWKEYS
debug1: SSH2_MSG_NEWKEYS received
debug1: SSH2_MSG_SERVICE_REQUEST sent
debug1: SSH2_MSG_SERVICE_ACCEPT received
debug1: Authentications that can continue: publickey
debug1: Next authentication method: publickey
debug1: Trying private key: /c/Wrong/Directory/.ssh/identity
debug1: Trying private key: /c/Wrong/Directory/.ssh/id_rsa
debug1: Trying private key: /c/Wrong/Directory/.ssh/id_dsa
debug1: No more authentication methods to try.
Permission denied (publickey).
Из приведенного выше вы могли заметить, что ssh ищет ключи в каталоге /c/Wrong/Directory/.ssh
, а не в том месте, где у нас есть открытые ключи, которые мы только что добавили в heroku (используя heroku keys:add ~/.ssh/id_rsa.pub
) (Обратите внимание, что в ОС Windows ~
относится к HOME
путь, который в выигрыше 7/8 равен C:\Users\UserName
)
Чтобы просмотреть текущий домашний каталог, выполните: echo $HOME
или echo %HOME%
(Windows)
Чтобы правильно установить каталог HOME
(под правильным я подразумеваю родительский каталог каталога .ssh
, чтобы ssh мог искать ключи в правильном каталоге) обратитесь к этим ссылкам:
SO Ответ о том, как установить среду Unix переменная постоянно
Вопрос SO относительно ssh, ищущего ключи в неправильном каталоге, и решения для него.
person
Community
schedule
19.05.2011
heroku login
затем написать адрес электронной почты и пароль и повторить попытку. - person Alejandro Veintimilla   schedule 07.06.2014