scp传输免输密码

2020-04-27  本文已影响0人  小东0818

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上执行同样过程。

上一篇 下一篇

猜你喜欢

热点阅读