linux - 远程拷贝文件之scp
简介
scp就是secure copy,是用来进行远程文件拷贝的。数据传输使用ssh1,并且和ssh1使用相同的认证方式,提供相同的安全保证。
scp只要通过sshd服务进行通讯,而且要求两端都有scp这个命令。
用法
scp [-pqrvBC1246] [-F ssh_config] [-S program] [-P port] [-c cipher] [-i identity_file]
[-l limit] [-o ssh_option] [[user@]host1:]file1 [...] [[user@]host2:]file2
常用方式
复制一个文件到远程主机
scp file 192.168.1.100:/tmp/
如果不指定用户名, 默认是跟当前的用户名是一样,如果是需要制定用户直接是[email protected];端口默认是ssh_config配置的端口(默认是22),如果IP后面不加路径,默认就是用户的家目录。
复制一个文件夹
scp -r dir1 192.168.1.100:/tmp/
复制目录需要添加一个-r参数,来递归复制。
注意:这里的目录中的软链接,如果是目录打软链接,会被当成正常的目录,复制所有打文件到远程,导致软链接都消失了。
拷贝多个文件或者目录
scp -r dir1 dir2 file1 file2 192.168.1.100:/tmp/
只要把目标放到最后,中间的文件目录都会被拷贝到远程的/tmp目录。
限速拷贝
scp -l 102400 -r dir 192.168.1.100:/tmp
-l 参数的单位是:Kbit/s,限速可以防止拷贝文件占用带宽,导致正常的服务出现异常。
自定义端口
scp -l 102400 -r -P 2222 dir [email protected]:/tmp
为了安全一点,有些ssh服务不使用默认端口了,这时候拷贝文件就需要指定端口,用-P这个参数(是大写的P)
指定密钥
scp -i /data/id_rsa -r dir [email protected]:/tmp
有些情况,是直接使用密钥进行验证的,如果不是本机默认打key,需要使用-i指定一下密钥打路径。
指定ssh_config配置文件
scp -F /data/ssh_config -r dir [email protected]:/tmp
scp调用的是ssh_config,有时候,我们自定义打一些参数,比如自动接受key之类的参数,又不想影响系统本身自带的配置。这时候就需要-F制定一下ssh客户端的配置。默认加载的是/etc/ssh/ssh_config
总结
scp使用起来简单方便,但是对于软链接的处理不是很人性化。可以先使用tar打包,然后再进行拷贝。
tar zcvf file.tar.gz dir1 file scp file.tar.gz 192.168.1.100:/tmp/