Vous devez télécharger votre clé publique sur Heroku:
heroku keys:add ~/.ssh/id_rsa.pub
Si vous ne disposez pas d'une clé publique, Heroku vous invite à ajouter automatiquement un qui fonctionne parfaitement. Utilisez simplement:
heroku keys:add
Pour supprimer toutes les clés précédentes n' :
heroku keys:clear
Pour afficher toutes les touches de faire :
heroku keys
EDIT:
Le ci-dessus ne semble pas fonctionner pour moi. J'avais foiré autour avec l' HOME
variable d'environnement et donc SSH était à la recherche pour les clés dans le mauvais répertoire.
Pour s'assurer que SSH recherche la clé dans le bon répertoire de faire :
ssh -vT git@heroku.com
Qui sera le suivant ( Exemple ) lignes de
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).
À partir de ci-dessus vous avez pu observer que ssh cherche les clés dans l' /c/Wrong/Directory/.ssh
répertoire qui n'est pas là où nous avons les clés publiques que nous venons d'ajouter à heroku ( à l'aide d' heroku keys:add ~/.ssh/id_rsa.pub
) ( Veuillez noter que dans l'OS de windows ~
se réfère à l' HOME
chemin qui win 7 / 8 C:\Users\UserName
)
À la vue de votre domicile actuel de l'annuaire : echo $HOME
ou echo %HOME%
( Windows )
Pour définir votre HOME
annuaire correctement ( par correctement, je veux dire le répertoire parent de l' .ssh
répertoire, de sorte que ssh pourrait chercher les clés dans le bon répertoire ), consultez ces liens :
DONC Réponse sur comment définir la variable d'environnement Unix de façon permanente
DONC, la Question concernant ssh à la recherche pour les clés dans le mauvais répertoire et une solution pour le même.