linux - 远程拷贝文件之scp

简介

scp就是secure copy,是用来进行远程文件拷贝的。数据传输使用ssh1,并且和ssh1使用相同的认证方式,提供相同的安全保证。

scp只要通过sshd服务进行通讯,而且要求两端都有scp这个命令。


linux  - 远程拷贝文件之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

linux  - 远程拷贝文件之scp


常用方式

复制一个文件到远程主机

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


linux  - 远程拷贝文件之scp

总结

scp使用起来简单方便,但是对于软链接的处理不是很人性化。可以先使用tar打包,然后再进行拷贝。

tar zcvf file.tar.gz dir1 file 
scp file.tar.gz 192.168.1.100:/tmp/