Linux传递文件scp

5月 12, 2023 85点热度 0人点赞 0条评论

scp介绍
scp是secure copy的简写,用于在Linux下进行远程拷贝文件的命令,和它类似的命令有cp,不过cp只是在本机进行拷贝不能跨服务器,而且scp传输是加密的。可能会稍微影响一下速度。当你服务器硬盘变为只读 read only system时,用scp可以帮你把文件移出来。另外,scp还非常不占资源,不会提高多少系统负荷,在这一点上,rsync就远远不及它了。虽然 rsync比scp会快一点,但当小文件众多的情况下,rsync会导致硬盘I/O非常高,而scp基本不影响系统正常使用。scp在夸机器复制的时候为了提高数据的安全性,使用了ssh连接和加密方式,如果机器之间配置了ssh免密码登录,那在使用scp的时候密码都不用输入。

scp的安装:文件传输的两端机器都需要安装

[root@yufu ~]# yum install openssh-clients -y
命令格式: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:192.168.214.190 B:192.168.214.187

[root@localhost tmp]#scp -p ./files/yum.log 192.168.214.187:/tmp/demo/
The authenticity of host '192.168.214.187 (192.168.214.187)' 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 '192.168.214.187' (RSA) to the list of known hosts.
root@192.168.214.187's password:
yum.log 100% 0 0.0KB/s 00:00
检查B主机文件:

[root@yufu demo]# ls
f3.log yum.log
[root@yufu demo]# ll
总用量 0
-rw-r--r--. 1 root root 0 3月 31 22:38 f3.log
-rw-------. 1 root root 0 3月 31 22:36 yum.log
将远程主机复制到本地

[root@localhost files]#scp -p 192.168.214.187:/tmp/demo/f3.log /tmp/files/
root@192.168.214.187's password:
f3.log 100% 0 0.0KB/s 00:00
[root@localhost files]#ls
f3.log ff.txt yum.log
复制目录

[root@localhost tmp]#scp -rp ./files/ 192.168.214.187:/tmp/demo
root@192.168.214.187's password:
f3.log 100% 0 0.0KB/s 00:00
yum.log 100% 0 0.0KB/s 00:00
ff.txt 100% 5 7.3KB/s 00:00
[root@localhost tmp]#
检查远程主机目录

[root@yufu demo]# tree
.
└── files
├── app
├── f3.log
├── ff.txt
└── yum.log

2 directories, 3 files

 

 

传文件

scp /data/dump/vzdump-qemu-200-2023_05_06-14_47_20.log root@116.55.22.15:/var/lib/vz/dump

传文件夹

scp -rp ./files/ root@192.168.214.187:/tmp/demo

 

带端口的

scp -P 1022 /data/images/201/vm-201-disk-2.qcow2 root@116.55.22.15:/var/lib/vz/images/101

 

李 锋

这个人很懒,什么都没留下

文章评论