scp时候需要输入密码有时候挺麻烦,尤其是密码比较难记,我们可以通过建立两server之间的信任关系,从此就不用输入密码了。
效果:server1可以不用密码就额可以scp到server2.这是一个单向过程,server2 scp到server1还是需要密码。
1. 在server1上root用户执行ssh-keygen命令,生成建立安全信任关系的证书。
[00:38:56]root@ubuntu:~# ssh-keygen -b 1024 -t rsa
[00:38:56]Generating public/private rsa key pair.
[00:39:25]Enter file in which to save the key (/root/.ssh/id_rsa):
[00:39:27]Enter passphrase (empty for no passphrase):<-- 直接输入回车
[00:39:28]Enter same passphrase again:<-- 直接输入回车
[00:39:28]Your identification has been saved in /root/.ssh/id_rsa.
[00:39:28]Your public key has been saved in /root/.ssh/id_rsa.pub.
[00:39:28]The key fingerprint is:
[00:39:28]31:b2:cd:0a:89:dc:eb:fa:7c:54:d3:af:76:08:87:c5 root@ubuntu
[00:39:28]The key's randomart image is:
[00:39:28]+--[ RSA 1024]----+
[00:39:28]| |
[00:39:28]| |
[00:39:28]| . o. |
[00:39:28]| . o . = oo .|
[00:39:28]|o + ..So o .|
[00:39:28]| o .E o .|
[00:39:28]| . .o . o |
[00:39:28]| o. + .|
[00:39:28]|.o+. . . |
[00:39:28]+-----------------+
注意:在程序提示输入passphrase时直接输入回车,表示无证书密码。
上述命令将生成私钥证书id_rsa和公钥证书id_rsa.pub,存放在用户家目录的.ssh子目录中。
2. 将公钥证书id_rsa.pub复制到机器Server2的root家目录的.ssh子目录中,同时将文件名更换为authorized_keys。
(注:如果server2已经有了authorized_keys,说明接受过其他服务器的申请,这时候需要将server1的id_rsa.pub的内容追加到server2的authorized_keys后面,用cat>>)
[00:44:14]root@ubuntu:~# scp -p /root/.ssh/id_rsa.pub root@server2:/root/.ssh/authorized_keys
[00:44:25]root@server2's password:<-- 输入Server2的root密码
[00:44:26]id_rsa.pub 100%225 0.2KB/s 00:00
经过以上2步,就在server1的root和机器Server2的root之间建立安全信任关系。下面我们看看效果:
在server1上执行:
[00:44:58]root@ubuntu:~# scp /opt/od.sh root@server2:/opt/xxj
[00:44:59]od.sh 100% 0 0.0KB/s00:00
ok,不再提示输入密码了。
如果需要server2也实现,需要在server2上执行同样过程。