[关闭]
@yangwenbo 2023-02-10T17:37:30.000000Z 字数 1606 阅读 524

centos7系统

Linux之scp命令的使用

1. scp简介

1.1 命令功能:

scp是 secure copy的缩写, scp是linux系统下基于ssh登陆进行安全的远程文件拷贝命令。linux的scp命令可以在linux服务器之间复制文件和目录。

格式为:scp [可选参数] file_source file_target

1.2 命令参数

  • -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. 命令实践

主机名 IP地址 备注
web01 192.168.200.28 测试服务器(一)
web02 192.168.200.29 测试服务器(二)

2.1 将本机文件复制到远程服务器上

  1. [root@web01 ~]# scp -r /root/test root@192.168.200.29:/tmp/
  2. #命令详解:
  3. /root 本地文件的绝对路径
  4. test 要复制到服务器上的本地文件
  5. root 通过root用户登录到远程服务器(也可以使用其他拥有同等权限的用户)
  6. 192.168.200.29 远程服务器的ip地址(也可以使用域名或机器名)
  7. /tmp 将本地文件复制到位于远程服务器上的路径

2.2 将远程服务器上的文件复制到本机

  1. [root@web01 ~]# scp -r root@192.168.200.29:/tmp/test /root/sc/
  2. #命令详解:
  3. root 通过root用户登录到远程服务器(也可以使用其他拥有同等权限的用户)
  4. 192.168.200.29 远程服务器的ip地址(也可以使用域名或机器名)
  5. /tmp/test 欲复制到本机的位于远程服务器上的文件
  6. /root/sc/ 将远程文件复制到本地的绝对路径

2.3 如果远程服务器防火墙有特殊限制,scp便要走特殊端口,具体用什么端口视情况而定,命令格式如下:

  1. [root@web01 ~]# scp -rP 1234 /root/test root@192.168.200.29:/tmp/

2.4 scp命令延申

  1. #对拷文件夹 (包括文件夹本身)
  2. [root@web01 ~]# scp -r /root/sc root@192.168.200.29:/tmp/
  1. #对拷文件夹下所有文件 (不包括文件夹本身)
  2. [root@web01 ~]# scp -r /root/sc/* root@192.168.200.29:/tmp/
  1. #对拷文件并重命名
  2. [root@web01 ~]# scp -r /root/test root@192.168.200.29:/tmp/test.txt
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注