SCP实现无需密码传输文件
Posted 23云恋49枫
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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
以上是关于SCP实现无需密码传输文件的主要内容,如果未能解决你的问题,请参考以下文章