scp是secure copy的简写,用于在Linux下进行远程拷贝文件的命令
scp优点:
相比于只能在本机进行拷贝的命令cp,scp不仅能远程传输而且传输还是加密的。
scp还非常不占资源,不会提高多少系统负荷,在这一点上,rsync就远远不及它了。
scp在夸机器复制的时候为了提高数据的安全性,使用了ssh连接和加密方式
scp缺点就是传输速度上会慢一点。
第一步:SCP的安装
在两台需要传输的文件的主机上都需要安装openssh-clients
[root@yufu ~]# yum install openssh-clients -y
SCP的命令格式及参数
scp [参数] [本地主机文件路径] [远程主机路径]
参数选项:
-1 强制scp命令使用协议ssh1
-2 强制scp命令使用协议ssh2
-4 强制scp命令只使用IPv4寻址
-6 强制scp命令只使用IPv6寻址
-B 使用批处理模式(传输过程中不询问传输口令或短语)
-C 允许压缩。(将-C标志传递给ssh,从而打开压缩功能)
-p 保留原文件的修改时间,访问时间和访问权限。 (建议使用,传输时保留属性时间信息,否则会导致时间发生改变无法进行增量传输)
-q 不显示传输进度条。 (很适合crontab任务计划中使用)
-r 递归复制整个目录。
-v 详细方式显示输出。scp和ssh(1)会显示出整个过程的调试信息。这些信息用于调试连接,验证和配置问题。
-c cipher 以cipher将数据传输进行加密,这个选项将直接传递给ssh。
-F ssh_config 指定一个替代的ssh配置文件,此参数直接传递给ssh。
-i identity_file 从指定文件中读取传输时使用的密钥文件,此参数直接传递给ssh。
-l limit 限定用户所能使用的带宽,以Kbit/s为单位。
-o ssh_option 如果习惯于使用ssh_config(5)中的参数传递方式,
-P port 注意是大写的P, port是指定数据传输用到的端口号
-S program 指定加密传输时所使用的程序。此程序必须能够理解ssh(1)的选项。
SCP的使用:
将本地A主机文件复制到B主机: A:10.10.158.214 B:10.10.158.86
[root@localhost tmp]#scp -p ./files/yum.log 10.10.158.86:/tmp/demo/
The authenticity of host '10.10.158.86 (10.10.158.86)' can't be established.
RSA key fingerprint is SHA256:BwJdXsDA6F5976fKx1cSxkGJ9/uYYI4zVJ2rd+/Cvj0.
RSA key fingerprint is MD5:85:87:8b:17:d2:79:c7:91:11:46:78:b3:4d:9d:dd:5a.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '10.10.158.86' (RSA) to the list of known hosts.
root@10.10.158.86's password:
yum.log 100% 0 0.0KB/s 00:00