scp免密码传输

背景

scp时候需要输入密码有时候挺麻烦,尤其是密码比较难记,我们可以通过建立两server之间的信任关系,从此就不用输入密码了。
有时候需要将命令行植入到程序中的时候,也需要免密码,这样,程序就可以直接执行得到结果了。

效果

  • 在a命令行上执行操作,可以复制文件到b,或者把b上的文件复制来。
  • 这是单向过程,如果在b上也想免密码登录a,这时候需要在b上做同样的操作。

步骤

  1. 在a命令行,root用户执行以下命令,生成建立安全信任关系的证书。
[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之间建立安全信任关系。下面我们看看效果:
3. 在a命令行输入:

[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 

不需要密码了~

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值