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 p_w_picpath 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/s  00:00 

ok,不再提示输入密码了。


如果需要server2也实现,需要在server2上执行同样过程。

出处:http://blog.sina.com.cn/s/blog_48ab118d0101gvpt.html