次のコマンド ラインを使用して、コードを heroku にデプロイしようとしています。
git push heroku master
しかし、次のエラーが発生します。
Permission denied (publickey).
fatal: The remote end hung up unexpectedly
すでに公開 SSH キーをアップロードしましたが、それでもこのエラーが発生します。
ベストアンサー1
公開鍵を 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 OS では、win 7/8 ではパスを~
参照することにHOME
C:\Users\UserName
注意してください)
現在のホームディレクトリを表示するには、次を実行します:echo $HOME
またはecho %HOME%
( Windows )
ディレクトリを正しく設定するにはHOME
(正しくとは、ディレクトリの親ディレクトリを意味し.ssh
、ssh が正しいディレクトリでキーを検索できるようにします)、次のリンクを参照してください。