Centos7 跨服务器批量传输文件(scp命令)
2023-07-21 本文已影响0人
有事找叮当
我们如果要将一台服务器(192.168.1.8)的文件批量拷贝到另一台服务器(192.168.1.9)上,命令如下:
$ scp root@192.168.1.8:/usr/local/oas/k8s/images/* root@192.168.1.9:/usr/local/oas/k8s/images/
上述命令是将 192.168.1.8 节点 /usr/local/oas/k8s/images/ 目录下的所有文件传输到 192.168.1.9 节点 /usr/local/oas/k8s/images/ 目录下,传输结果,图示如下:
image.png如果只是单文件(coredns.tar.gz)传输则执行以下命令:\
$ scp root@192.168.1.8:/usr/local/oas/k8s/images/coredns.tar.gz root@192.168.1.9:/usr/local/oas/k8s/images/
简易写法
scp [可选参数] file_source file_target
# 参数说明
-1 强制 scp 命令使用协议 ssh1
-2 强制 scp 命令使用协议 ssh2
-4 强制 scp 命令只使用 IPv4 寻址
-6 强制 scp 命令只使用 IPv6 寻址
-B 使用批处理模式(传输过程中不询问传输口令或短语)
-C 允许压缩(将 -C 标志传递给 ssh ,从而打开压缩功能)
-p 保留原文件的修改时间,访问时间和访问权限
-q 不显示传输进度条
-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) 的选项
2.1 远程拷贝文件/文件夹
# 拷贝本机单个文件至远程主机 root 用户的家目录下
scp /root/test/test.txt root@remot_ip:~/
# 拷贝本机 /root/test 整个目录至远程主机 root 用户的家目录下
scp -r /root/test root@remot_ip:~/
2.2 远程文件/文件夹下载
# 把远程端上面的 /root/ 文件夹,下载到本地的 /home/test/test/ 下,使用远程端的 root 登录
scp -r root@remot_ip:/root/ /home/test/test/