1. ホーム
  2. git

[解決済み] herokuコードのデプロイ時にパーミッションが拒否される(publickey) fatal: リモートエンドが予期せずハングアップする

2022-02-19 21:54:04

質問内容

次のコマンドラインで、自分のコードをherokuにデプロイしようとしています。

git push heroku master

が、以下のようなエラーが発生します。

Permission denied (publickey).
fatal: The remote end hung up unexpectedly

すでに公開SSH鍵をアップロードしていますが、まだこのエラーが出ます。

解決方法を教えてください。

公開鍵をHerokuにアップロードする必要があります。

heroku keys:add ~/.ssh/id_rsa.pub

公開鍵を持っていない場合、Herokuは自動的に公開鍵を追加するよう促します。これはシームレスに動作します。ただ使うだけです。

heroku keys:add

以前のキーをすべて消去するには、次のようにします。

heroku keys:clear

既存のキーをすべて表示するには、次のようにします。

heroku keys

EDIT

上記は私の場合はうまくいかなかったようです。私は 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では ~ とは HOME のパスで、Win 7 / 8 では C:\Users\UserName )

現在のホームディレクトリを表示するには、次のようにします。 echo $HOME または echo %HOME% ( Windows )

を設定するには HOME の親ディレクトリが正しいことを意味します。 .ssh ディレクトリにあるキーを探せるようにするため、これらのリンクを参照してください。

  1. SO Unix環境変数を永続的に設定する方法についてお答えします。

  2. SO sshが間違ったディレクトリにあるキーを探すことについての質問とその解決策。