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

 

posted on 2017-02-22 18:02  23云恋49枫  阅读(2525)  评论(0编辑  收藏  举报