SCP实现无需密码传输文件

SCP概述

Linux为我们提供了两个用于文件copy的命令,一个是cp,一个是scp,但是他们略有不同

CP ----- 主要是用于在同一台电脑上,在不同的目录之间来回copy文件 
SCP --- 主要是在不同的Linux系统之间来回copy文件 

下面我们就主要讲一下SCP命令的基本用法:

scp 传输文件路径 用户名@传输文件目标IP:目标路径(可以指定新的文件名)

在Linux环境下,两台主机之间传输文件一般使用scp命令,通常用scp命令通过ssh获取对方linux主机文件的时候都需要手动输入密码确认。

最近的一个项目中就遇到了这个问题,利用os模块的os.system()来执行系统命令来完成定时任务,我们不可能手动输入密码,而应该实现无密传输,我们可以通过建立信任关系,可以实现不输入密码而进行数据传输。

假设俩个服务器A:192.168.111.100,服务器B:192.168.111.101之间进行数据传输:

1、在主机A上执行如下命令来生成配对密钥: (按照提示操作,注意,不要输入passphrase,一直回车完成)

ssh-keygen -t rsa 

2、查看B主机上面是否存在authorized_keys文件,如果没有此文件, 将A主机.ssh 目录中的 id_rsa.pub 文件复制到 主机B 的 ~/.ssh/ 目录中,并改名为  authorized_keys

scp .ssh/id_rsa.pub 192.168.111.101:/root/.ssh/authorized_keys

如果B主机上存在authorized_keys文件,则需注意,这个文件可以包含多个SSH验证信息,这时先把id_rsa.pub文件传到B主机的/root/.ssh目录下面(重新命名文件名),然后再利用 cat >>命令将验证文件内容附加上去

比如复制到scp .ssh/id_rsa.pub 192.168.111.101:/root/.ssh/a.pub

然后执行cat ~/.ssh/a.pub >> ~/.ssh/authorized_keys

 

转载于:https://www.cnblogs.com/luxiaojun/p/6428186.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值