Permiso denegado (clave pública) al implementar el código heroku. fatal: el extremo remoto se colgó inesperadamente
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.
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 HOME
variable 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/.ssh
directorio 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 HOME
ruta que en Win 7/8 esC:\Users\UserName
)
Para ver su directorio de inicio actual haga: echo $HOME
o echo %HOME%
(Windows)
Para configurar su HOME
directorio correctamente (por correctamente me refiero al directorio principal del .ssh
directorio, para que ssh pueda buscar claves en el directorio correcto), consulte estos enlaces:
Entonces responda sobre cómo configurar la variable de entorno Unix de forma permanente
SO Pregunta sobre ssh buscando claves en el directorio incorrecto y una solución para el mismo.
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
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]