Musisz wgrać swój klucz publiczny do Heroku:
heroku keys:add ~/.ssh/id_rsa.pub
Jeśli nie masz klucza publicznego, Heroku poprosi Cię o dodanie go automatycznie, który działa bezproblemowo. Po prostu użyj:
heroku keys:add
Aby wyczyścić wszystkie poprzednie klucze:
heroku keys:clear
Aby wyświetlić wszystkie istniejące klucze:
heroku keys
EDYTOWAĆ:
Wydawało mi się, że powyższe nie działa. Pomieszałem ze HOME
zmienną środowiskową, więc SSH szukało kluczy w niewłaściwym katalogu.
Aby upewnić się, że SSH sprawdza klucz w poprawnym katalogu:
ssh -vT git@heroku.com
Które wyświetlą następujące (przykładowe) linie
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).
Z powyższego można zauważyć, że ssh szuka kluczy w /c/Wrong/Directory/.ssh
katalogu, w którym nie ma kluczy publicznych, które właśnie dodaliśmy do heroku (za pomocą heroku keys:add ~/.ssh/id_rsa.pub
) ( Należy pamiętać, że w systemie operacyjnym Windows ~
odnosi się do HOME
ścieżki, która w winC:\Users\UserName
7/8 jest )
Aby wyświetlić bieżący katalog domowy, wykonaj: echo $HOME
lub echo %HOME%
(Windows)
Aby ustawić HOME
poprawnie katalog (poprawnie rozumiem katalog nadrzędny katalogu .ssh
, aby ssh mógł szukać kluczy w odpowiednim katalogu), skorzystaj z poniższych linków:
SO Odpowiedz na to, jak na stałe ustawić zmienną środowiskową Unix
SO Pytanie dotyczące ssh szukającego kluczy w niewłaściwym katalogu i rozwiązania tego samego.