部署heroku代码时权限被拒绝(publickey)。致命:远程端意外挂断

时间:2010-11-24 17:51:14

标签: git heroku deployment public-key

我正在尝试使用以下命令行将代码部署到heroku:

git push heroku master

但收到以下错误:

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

我已经上传了我的公共SSH密钥,但它仍然会出现此错误。

34 个答案:

答案 0 :(得分:1460)

您必须将公钥上传到Heroku:

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

如果您没有公钥,Heroku将提示您自动添加一个公钥,无缝工作。只需使用:

heroku keys:add

要清除以前的所有按键,请执行以下操作:

heroku keys:clear

要显示所有现有密钥,请执行以下操作:

heroku keys

编辑:

以上似乎对我没有用。我弄乱了HOME环境变量,因此SSH正在错误的目录中搜索密钥。

要确保SSH检查正确目录中的密钥,请执行以下操作:

ssh -vT git@heroku.com

将显示以下(样本)行

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 $HOMEecho %HOME%(Windows)

正确设置HOME目录(正确地说,我是指.ssh目录的父目录,以便ssh可以在正确的目录中查找密钥),请参阅以下链接:

  1. SO Answer on how to set Unix environment variable permanently

  2. SO Question regarding ssh looking for keys in the wrong directory and a solution for the same.

答案 1 :(得分:144)

我遇到了同样的问题,下面的步骤对我有用,

->heroku login

abc@gmail.com&amp;密码

->cd C:\Users\yourusername\.ssh    (OR for cygwin shell ->cd ~/.ssh)

->ssh-keygen -t rsa -f id_rsa

如果要求任何密码不使用空白,请填写密码,但不要忘记密码。

生成密钥后,您需要添加密钥,如此

$ ssh-add

和它到heroku

->heroku keys:add "id_rsa.pub"

将目录更改为工作区,而不是

->git clone git@heroku.com:stark-dawn-1234.git -o heroku

使用您在上面设置的密码。


其实我也删除了下面的文件,但不确定它们是否为

C:\ Users \ yourusername.heroku \ credientals and C:\ Users \ yourusername.ssh \ known_hosts

答案 2 :(得分:90)

这个问题让我困扰了几天。

这可能会有所帮助。

1)找出你现在在Heroku中拥有的按键。

$ heroku keys
=== 1 key for joe@example.com
ssh-dss AAAAB8NzaC...DVj3R4Ww== joe@workstation.local

2)构建〜/ .ssh / config文件:

$ sudo vim ~/.ssh/config

使用此信息进行编辑

Host heroku.com
Hostname heroku.com 
Port 22 
IdentitiesOnly yes 
IdentityFile ~/.ssh/ssh-dss # location and name of your private key
TCPKeepAlive yes 
User joe@workstation.local

答案 3 :(得分:61)

以下是解释如何管理ssh密钥的链接:http://devcenter.heroku.com/articles/keys#adding_keys_to_heroku

答案 4 :(得分:34)

我有同样的问题,因为我没有公钥,所以我做了:

heroku keys:clear
heroku keys:add

这将生成一个公钥然后效果很好

答案 5 :(得分:31)

如果您是Windows用户,此处的其他解决方案可能无法解决您的问题。

我使用Windows 7 64-Bit + Git-1.7.7.1-preview20111027,解决方案是将我的密钥从C:\users\user\.ssh复制到C:\Program Files (x86)\Git\.ssh。这就是这个git客户端在推送到heroku时寻找密钥的地方。

我希望这会有所帮助。

答案 6 :(得分:29)

这是我的解决方案:

ssh-add ~/.ssh/my_heroku_key_rsa

答案 7 :(得分:15)

分享我的经验:

Git(我自己的安装)正在寻找名为'id_rsa'的密钥。

所以我尝试将我的密钥重命名为'id_rsa'和'id_rsa.pub',然后就可以了。

不过,我确信还有其他方法可以做到这一点,但我看起来还不够深。

答案 8 :(得分:11)

如果您已经上传了密钥,请尝试删除该密钥,然后重新上传 用一把新钥匙。

 heroku keys:remove //removes the existing key
 ssh-keygen -t rsa //generates a new key in ~/.ssh folder
 heroku keys:add    //uploads the new key, if no arguments r passed then the key generated                              
                    //in default directroy i.e., ~/.ssh/id_rsa is uploaded
 git push heroku

这应该有效。

答案 9 :(得分:7)

我自杀了3天尝试了所有可能的组合,试图让它发挥作用 - 我终于尝试制作一个 DSA 键而且它有效。

如果它不适合您,请尝试DSA而不是RSA。

(我使用的是Ubuntu 11.10,ruby 1.8.7,heroku 2.15.1)

答案 10 :(得分:6)

在Windows 7,64位上,上面的解决方案(Onur Turhan)对我有用,稍有改动,如下所示

C:\Users\MyName > heroku login

输入电子邮件/密码

C:\Users\MyName >ssh-keygen -t rsa -f id_rsa

这在我的c:\ Users \ MyName目录中生成了两个文件(id_rsa和id_rsa.pub)(不在.ssh目录中)

heroku keys:add id_rsa.pub
git clone git@heroku.com:some-heiku-xxxx.git -o heroku

我想添加正确的“id_rsa.pub”文件是最重要的。使用keygen生成公钥后,只需通过查看创建时的时间戳来验证是否正在添加正确的密钥。

答案 11 :(得分:5)

在我的机器上安装TortoiseGIT时遇到了这个问题。从

更改环境变量GIT_SSH
"c:\Program Files\TortoiseGit\bin\TortoisePlink.exe"

"c:\Program Files (x86)\Git\bin\ssh.exe"

并在本教程中使用ssh-keygenkeys:add,它可以正常工作!

答案 12 :(得分:5)

单个命令有效:

heroku keys:add

如果它不存在,它将成为一个。

答案 13 :(得分:4)

Pushing正在为我工​​作,然后突然停了下来。

如果heroku api遇到停机时间,当您尝试推送时会出现此错误。

检查:

https://status.heroku.com/

之前吓坏了。

答案 14 :(得分:3)

要遵循的顺序

$ heroku login
$ ssh-keygen -t rsa
$ heroku keys:add

当执行第二个语句时,它会要求输入,只需按 Enter (返回)三次,就会添加一个键。

答案 15 :(得分:2)

上面给出的答案可行,但发现我需要在它工作之前做一些额外的步骤。

  1. 我删除了所有id_rsa *文件,并使用this指南生成了新的SSH。
  2. 然后,我销毁了heroku app。删除了〜/ .heroku /凭证文件。
  3. 'heroku create'命令(自从凭据文件被删除后,它会提示您输入电子邮件/密码。
  4. 最后输入'heroku keys:add',它会上传默认的〜/ .ssh / id_rsa.pub文件。
  5. 有效!嗯.... YMMV,但我真的希望这可以提供一些帮助,因为我整天都在努力解决这个问题!哈哈

答案 16 :(得分:2)

对于那些在Windows 7上尝试过上述所有内容并仍然无法正常工作的人来说,这就是我所做的: - 从Git目录C:\ Program Files(x86)\ Git \打开GitBash.exe(不要打开命令提示符,这不起作用)。 - 按照above添加以下内容,但您必须删除#

Host heroku.com
Hostname heroku.com 
Port 22 
IdentitiesOnly yes 
IdentityFile ~/.ssh/ssh-dss
TCPKeepAlive yes 
User joe@workstation.local

现在运行 git push heroku master ,它应该可以运行。

答案 17 :(得分:1)

我必须这样做:

$ ssh-keygen -t rsa  
$ heroku keys:add  

然后它奏效了:

$ git push heroku master  

答案 18 :(得分:1)

听起来您的~/.ssh/authorized_keys文件设置不正确。验证:

  • 这是正确的道路。
  • 该文件的权限为0600。
  • ~/.ssh的权限为0700。

答案 19 :(得分:1)

检查你的.ssh配置是否为heroku。转到.ssh文件夹并打开配置文件

cd ~/.ssh
subl config

'subl'适用于Sublime Text,但您可以使用任何您想要的编辑器。查找“IdentityFile”行,并确保列出非公钥:

IdentityFile "/Users/ircmullaney/.ssh/my_ssh"

IdentityFile "/Users/ircmullaney/.ssh/my_ssh.pub"

那为我做了。我不确定为什么我的配置文件中有公共版本,但它确实发生了错误:

Permissions 0644 for '/Users/ircmullaney/.ssh/my_ssh.pub' are too open.

答案 20 :(得分:1)

在尝试所有这些想法后,我仍然遇到了问题。这是我的问题:

我的远程heroku存储库很有趣。我刷新如下:

git remote -v

然后删除错误的heroku:

git remote rm heroku

然后添加新的

git remote add heroku git@heroku.com:sitename.git

您可以从您的应用程序的Heroku设置页面获取网站名称。祝你好运!

答案 21 :(得分:1)

我遇到的问题是在Windows上,每当我运行“heroku keys:add”时,它都会选择github密钥。以下是我为解决问题而采取的步骤

  1. 转到“Doc​​ument and Settings”文件夹下的.ssh目录并删除了git hub keys
  2. 运行命令 heroku键:添加
  3. 上面的命令让我生成一个新密钥,然后是输出     找不到现有的公钥。     你想生成一个吗? [Yn] Y.     生成新的SSH公钥。     上传SSH公钥C:/ Documents and Settings / Admin / .ssh / id_rsa.pub ...完成     ! 'heroku'gem已被弃用并替换为Heroku Toolbelt,从https://toolbelt.heroku.com下载并安装。

    1. 重新运行命令 heroku键:添加
    2. 以上命令不会给出以下输出     找到现有公钥:C:/ Documents and Settings / Admin / .ssh / id_rsa.pub     上传SSH公钥C:/ Documents and Settings / Admin / .ssh / id_rsa.pub ...完成

      1. 现在使用git push heroku master
      2. 对我来说,使用上述步骤解决了这个问题,并且能够在云上部署应用程序。

答案 22 :(得分:1)

我遇到了同样的问题;遵循这些步骤应该有所帮助:

  1. 首先,登录:heroku login
  2. 清除所有键:heroku键:清除
  3. 删除.pub
  4. 中本地文件夹中的所有文件(所有know_host个文件和.ssh/ folder
  5. 再次登录:heroku登录 - 您将在没有密钥的情况下提示,因此请按照屏幕上的说明进行操作。

答案 23 :(得分:0)

我重新安装了heroku toolbelt,但它确实有用。

答案 24 :(得分:0)

如果你想使用“sudo”,例如:

sudo git clone git@heroku.com......... -o heroku

您还应该为root用户生成ssh密钥。

sudo su
cd /root/.ssh  
ssh-keygen -t rsa
....
heroku keys:add id_rsa.pub

它会起作用。

如果您不使用root用户,请改为在您的用户目录中生成ssh密钥。

cd /home/user/.ssh

很抱歉,如果我的句子搞砸了......

答案 25 :(得分:0)

您也可以尝试Heroku的新beta HTTP Git支持,而不是处理SSH密钥。它只使用您的API令牌并在端口443上运行,因此没有SSH密钥或端口22可以搞乱。

要使用HTTP Git,首先要确保更新Toolbelt并确认您的凭据是最新的:

$ heroku update
$ heroku login

(这很重要,因为Heroku HTTP Git的验证方式与Toolbelt的其余部分略有不同)

在测试期间,您可以通过将--http-git标记传递到相关的heroku apps:createheroku git:cloneheroku git:remote命令来获取HTTP。要创建新应用并使用HTTP Git远程配置,请运行以下命令:

$ heroku apps:create --http-git

要将现有应用程序从SSH更改为HTTP Git,只需从计算机上的应用程序目录运行此命令:

$ heroku git:remote --http-git
Git remote heroku updated

查看Dev Center documentation for details on how set up HTTP Git for Heroku

答案 26 :(得分:0)

如果其他答案对你不起作用。试试这个!

有时您需要的只是再次推动。由于互联网连接速度缓慢(当您下载或使用p2p时),今天发生在我身上。

请看下面的截图:

enter image description here

答案 27 :(得分:0)

使用

推送时
git push heroku production:master 

使用主目录下的公钥〜/ .ssh / id_rsa

解决此问题

您应该以其他用户身份登录

sudo su 

然后通过发出以下命令开始新鲜

heroku keys:clear //removes existing keys
ssh-keygen -t rsa //generates a new key in ~/.ssh folder (set a password)
heroku keys:add   //uploads the new key, ~/.ssh/id_rsa is uploaded                      
git push heroku production:master

答案 28 :(得分:0)

这对我有用。 heroku站点未添加到您的已知主机。转到window-other-show view-git-git存储库。从那里克隆存储库。克隆它后,删除刚刚创建的存储库,然后从文件菜单中导入它。这样做是因为克隆存储库时,它不会将其添加到资源管理器视图中。现在您应该拥有git存储库和资源管理器视图。

答案 29 :(得分:0)

dmajkic的解决方案终于帮助了我:

对于Windows用户,这可能意味着:git客户端无法找到您的密钥。 检查c:\ Users \ UserName.ssh \和中的键!环境变量HOME = c:\ Users \ UserName \

答案 30 :(得分:0)

我也有这个问题。我正在使用Mac OSX。我修复的方式是以管理员身份登录

  

sudo su

     

密码

答案 31 :(得分:0)

首先确保Mac中可以看到隐藏文件。 如果不这样做:

  • 打开终端并输入defaults write com.apple.Finder AppleShowAllFiles TRUE
  • killall Finder

后续步骤:

  • 转到Users/user_name/.ssh/删除了所有文件。
  • ssh-keygen -t dsa
  • 中打开终端类型
  • 然后heroku keys:add ~/.ssh/id_dsa.pub

N.B。我在Mac OSX 10.7.2 Lion中做到了。虽然程序在其他方面也应该相同。

答案 32 :(得分:0)

尝试修复“磁盘工具”(Mac OS X)中的权限。帮帮我

答案 33 :(得分:0)

我只想添加该目录不一定是C:\ Users \ [用户名] \ .ssh。它是您在其中创建公钥的目录。

例如,我在Windows中的主目录已更改为C:\ [用户名]。 .ssh子文件夹中的主目录是您创建密钥的最佳位置。您可以使用以下命令检查Windows中的主目录:

    echo %HOMEPATH%