id_dsa
そこにいないようで試しましたがそこにid_ecdsa
います。何度も再生成しようとしましたが、まだ動作しません。同じ問題を抱えて解決した人はいますか?それともこれを処理する方法を知っている人はいますか?
hadoop@i5:~$ ssh-keygen -t dsa
Generating public/private dsa key pair.
Enter file in which to save the key (/opt/hadoop/.ssh/id_dsa):
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /opt/hadoop/.ssh/id_dsa.
Your public key has been saved in /opt/hadoop/.ssh/id_dsa.pub.
The key fingerprint is:
2f:ea:1d:fa:eb:3b:86:ac:5f:32:0e:10:e1:09:c5:82 hadoop@i5
The key's randomart image is:
+--[ DSA 1024]----+
|ooo |
|Eo.o |
| .+ |
| . |
| . S |
| . . |
| ..o.+ . |
| ooBoo |
| .+*+*+ |
+-----------------+
hadoop@i5:~$ cat ~/.ssh/id_dsa.pub >> ~/.ssh/authorized_keys
hadoop@i5:~$ ssh localhost -v
OpenSSH_6.6.1, OpenSSL 1.0.1f 6 Jan 2014
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 19: Applying options for *
debug1: Connecting to localhost [127.0.0.1] port 22.
debug1: Connection established.
debug1: identity file /opt/hadoop/.ssh/id_rsa type -1
debug1: identity file /opt/hadoop/.ssh/id_rsa-cert type -1
debug1: identity file /opt/hadoop/.ssh/id_dsa type 2
debug1: identity file /opt/hadoop/.ssh/id_dsa-cert type -1
debug1: identity file /opt/hadoop/.ssh/id_ecdsa type -1
debug1: identity file /opt/hadoop/.ssh/id_ecdsa-cert type -1
debug1: identity file /opt/hadoop/.ssh/id_ed25519 type -1
debug1: identity file /opt/hadoop/.ssh/id_ed25519-cert type -1
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_6.6.1p1 Ubuntu-2ubuntu2.7
debug1: Remote protocol version 2.0, remote software version OpenSSH_6.6.1p1 Ubuntu-2ubuntu2.7
debug1: match: OpenSSH_6.6.1p1 Ubuntu-2ubuntu2.7 pat OpenSSH_6.6.1* compat 0x04000000
debug1: SSH2_MSG_KEXINIT sent
debug1: SSH2_MSG_KEXINIT received
debug1: kex: server->client aes128-ctr [email protected] none
debug1: kex: client->server aes128-ctr [email protected] none
debug1: sending SSH2_MSG_KEX_ECDH_INIT
debug1: expecting SSH2_MSG_KEX_ECDH_REPLY
debug1: Server host key: ECDSA a5:59:74:76:e5:37:42:3a:3b:57:50:be:a6:69:57:63
debug1: Host 'localhost' is known and matches the ECDSA host key.
debug1: Found key in /opt/hadoop/.ssh/known_hosts:1
debug1: ssh_ecdsa_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,password
debug1: Next authentication method: publickey
debug1: Trying private key: /opt/hadoop/.ssh/id_rsa
debug1: Offering DSA public key: /opt/hadoop/.ssh/id_dsa
debug1: Authentications that can continue: publickey,password
debug1: Trying private key: /opt/hadoop/.ssh/id_ecdsa
debug1: Trying private key: /opt/hadoop/.ssh/id_ed25519
debug1: Next authentication method: password
hadoop@localhost's password:
答え1
パスワードのないSSH接続を作成するには、まずキーペアを作成する必要があります(PuTTygenはこれに最適なツールです)。
キーを生成します。公開鍵と秘密鍵をコンピュータのどこかに保存します。サーバーの $HOME ディレクトリでmkdir .ssh
コマンドを使用して、.ssh というディレクトリを作成します。次に、コマンドを使用して "authorized_keys"というファイルを作成しますvi .ssh/authorized_keys
。公開鍵をコピーしてこのファイルに貼り付けます(viからi
挿入モードに入り、ESC
コマンドモードに戻って書き込んで:wq
終了します)。次に、chmod 700 .ssh/
サーバーを使用してシャットダウンしながら権限を調整します。最後に、PuTTYで左側の「Connect」をクリックしてツリーを展開します。次にSSHをクリックしてからAUTHをクリックします。 「認証のための秘密鍵ファイル」というフィールドがあります。秘密鍵を保存したディレクトリに移動して、このファイルを使用してください。
次のログイン時にパスワードなしでログインできます。
窓の場合: http://www.tecmint.com/ssh-passwordless-login-with-putty/
Linuxの場合: http://www.tecmint.com/ssh-passwordless-login-using-ssh-keygen-in-5-easy-steps/
編集 - 以下のコメントによると、権限の問題のようです。