在Linux系统运维中,我们可能会遇到这样的问题:当我们用客户端PUTTY利用key验证分别登录到主机A,主机B,主机C的时候,都不用输入密码,直接由key验证可以成功登录,那么我想从主机A登录到主机B,再从主机B登录到主机C的时候,要怎么做才能实现直接用key验证,而不用被要求输入密码呢?
这个时候我们需要在主机A和PUTTY上开启key转发功能,见下图:
钥匙生成和分发
1.在主机A上生成密钥对
[root@ws128 ~]# ssh-keygen(默认算法为RSA,2048位)
Generating public/privatersa key pair.
Enter file in which tosave the key (/root/.ssh/id_rsa):
Enter passphrase (emptyfor no passphrase):(输入私钥密码)
Enter same passphraseagain:
Your identification hasbeen saved in /root/.ssh/id_rsa.
Your public key has beensaved in /root/.ssh/id_rsa.pub.
The key fingerprint is:
c7:67:a8:4e:1b:e6:a2:43:ef:59:a0:10:48:67:f8:f2root@ws128.example.com
2.将生成的公钥分别安装到主机B、主机C上
[root@ws128 ~]# ssh-copy-id -i .ssh/id_rsa.pubroot@192.168.80.129
[root@ws128 ~]# ssh-copy-id -i .ssh/id_rsa.pub root@192.168.80.130
3.将私钥文件拷贝到终端,由于Linux的ssh-keygen生成的私钥文件PUTTY不识别,所以要用pttygen软件做一次转换,打开puttygen软件导入私钥,然后另存为PPK格式。
私钥转发配置
1.PUTTY配置,开启私钥转发,指定私钥文件,如图:
2.在主机A上开启SSH代理
[root@ws128 .ssh]# eval`ssh-agent`
Agent pid 3850
[root@ws128 .ssh]# ssh-add
Enter passphrase for/root/.ssh/id_rsa:
Identity added: /root/.ssh/id_rsa(/root/.ssh/id_rsa)
脚本实现
Vim /root/sshagent.sh
#!/usr/bin/expect
spawn ssh-add
expect "passphrase"
send "redhat\r"
expect eof
exit
Vim /root/.bashrc
Eval `ssh-agent`
/root/sshagent.sh
3.在主机A上设置SSH代理转发
[root@ws128 .ssh]# vim /etc/ssh/ssh_config
ForwardAgent yes
ForwardX11 yes
验证
1.在主机A上用SSH登录到主机B,然后在主机B上看能不能不用密码直接登录到主机C,如果可以,则配置成功。