Permiso denegado (clave pública) al implementar el código heroku. fatal: el extremo remoto se colgó inesperadamente

Resuelto asked hace 14 años • 34 respuestas

Estoy intentando implementar mi código en heroku con la siguiente línea de comando:

git push heroku master

pero aparece el siguiente error:

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

Ya cargué mi clave SSH pública, pero todavía aparece este error.

 avatar Nov 25 '10 00:11
Aceptado

Tienes que subir tu clave pública a Heroku:

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

Si no tiene una clave pública, Heroku le pedirá que agregue una automáticamente, la cual funciona perfectamente. Solo usa:

heroku keys:add

Para borrar todas las claves anteriores, haga lo siguiente:

heroku keys:clear

Para mostrar todas sus claves existentes, haga lo siguiente:

heroku keys

EDITAR:

Lo anterior no pareció funcionar para mí. Había jugado con la HOMEvariable de entorno y SSH estaba buscando claves en el directorio equivocado.

Para asegurarse de que SSH busque la clave en el directorio correcto, haga lo siguiente:

ssh -vT [email protected]

Que mostrará las siguientes líneas (muestra)

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).

De lo anterior se puede observar que ssh busca las claves en el /c/Wrong/Directory/.sshdirectorio que no es donde tenemos las claves públicas que acabamos de agregar a heroku (usando heroku keys:add ~/.ssh/id_rsa.pub) ( tenga en cuenta que en el sistema operativo Windows ~se refiere a la HOMEruta que en Win 7/8 esC:\Users\UserName )

Para ver su directorio de inicio actual haga: echo $HOMEo echo %HOME%(Windows)

Para configurar su HOMEdirectorio correctamente (por correctamente me refiero al directorio principal del .sshdirectorio, para que ssh pueda buscar claves en el directorio correcto), consulte estos enlaces:

  1. Entonces responda sobre cómo configurar la variable de entorno Unix de forma permanente

  2. SO Pregunta sobre ssh buscando claves en el directorio incorrecto y una solución para el mismo.

Raghav RV avatar May 19 '2011 13:05 Raghav RV

Tuve el mismo problema, los pasos a continuación funcionaron para mí,

->heroku login

[email protected] y contraseña

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

->ssh-keygen -t rsa -f id_rsa

Si solicita alguna frase de contraseña, no use espacios en blanco, complete con una frase de contraseña, pero no la olvide.

Después de generar la clave, debes agregarla, así

$ ssh-add

y a heroku

->heroku keys:add "id_rsa.pub"

cambiar el directorio al espacio de trabajo, que

->git clone [email protected]:stark-dawn-1234.git -o heroku

use la frase de contraseña que estableció anteriormente.


En realidad, también elimino los archivos siguientes, pero no estoy seguro de que sean imp.

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

Onur Turhan avatar Nov 03 '2011 10:11 Onur Turhan

Este problema me estuvo molestando durante unos días.

Esto podría ayudar.

1) Descubra qué claves tiene ahora en Heroku.

$ heroku keys
=== 1 key for [email protected]
ssh-dss AAAAB8NzaC...DVj3R4Ww== [email protected]

2) Cree un archivo ~/.ssh/config:

$ sudo vim ~/.ssh/config

Editar con esta información

Host heroku.com
Hostname heroku.com 
Port 22 
IdentitiesOnly yes 
IdentityFile ~/.ssh/ssh-dss # location and name of your private key
TCPKeepAlive yes 
User [email protected]
jkpham avatar Jan 16 '2012 01:01 jkpham