O SSH aceita a autenticação de chave pública, mas não se conectará com um arquivo de identificação?

1

Problema

Eu recentemente mudei para um novo servidor web. Eu estava usando arquivos de identificação com SSH para conectar no servidor anterior sem problemas, mas no novo servidor não consigo usar um arquivo de identificação para autenticar. Parece que ele tenta lê-lo, mas depois passa para a autenticação por senha. Eu acredito que meus arquivos estão certos - eu configurei isso tantas vezes!

Configuração

Gerei o arquivo de identificação no servidor remoto usando ssh-keygen , depois copiei a chave privada (id_rsa) de volta para o meu computador como ~/.ssh/id_remote_private . As permissões estão definidas corretamente (700/600 em ~ / .ssh e os arquivos dentro), tanto localmente quanto remotamente.

Log de conexão

Abaixo está o log de conexão da chave sem uma frase secreta. Além disso, não tenho certeza se isso é relevante, mas quando tentei usar uma passphrase, eu recebia um erro adicional: PEM_read_PrivateKey failed .

O que estou fazendo de errado aqui?

local_user$ ssh -v -i $HOME/.ssh/id_remote_private -l user1234 123.123.123.123
OpenSSH_5.2p1, OpenSSL 0.9.8l 5 Nov 2009

debug1: Reading configuration data /Users/local_user/.ssh/config
debug1: Reading configuration data /etc/ssh_config
debug1: Connecting to 123.123.123.123 [123.123.123.123] port 22.
debug1: Connection established.
debug1: identity file /Users/local_user/.ssh/id_remote_private type -1
debug1: Remote protocol version 2.0, remote software version OpenSSH_4.3
debug1: match: OpenSSH_4.3 pat OpenSSH_4*
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_5.2
debug1: SSH2_MSG_KEXINIT sent
debug1: SSH2_MSG_KEXINIT received
debug1: kex: server->client aes128-ctr hmac-md5 none
debug1: kex: client->server aes128-ctr hmac-md5 none
debug1: SSH2_MSG_KEX_DH_GEX_REQUEST(1024<1024<8192) sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_GROUP
debug1: SSH2_MSG_KEX_DH_GEX_INIT sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_REPLY
debug1: Host '123.123.123.123' is known and matches the RSA host key.
debug1: Found key in /Users/user/.ssh/known_hosts:43
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,gssapi-with-mic,password
debug1: Next authentication method: publickey
debug1: Trying private key: /Users/user/.idssh/id_remote_private
debug1: read PEM private key done: type RSA

debug1: Authentications that can continue: publickey,gssapi-with-mic,password
debug1: Next authentication method: password
[email protected]'s password: 
    
por cwd 17.05.2011 / 17:04

1 resposta

3

Se ainda não o fez, adicione a parte pública da sua chave a ~/.ssh/authorized_keys no lado remoto.

Você também pode verificar o conteúdo de /var/log/auth.log no lado remoto para obter mais detalhes.

    
por 17.05.2011 / 17:11