Linux scp 命令用于 Linux 之间复制文件和目录。
scp 是 secure copy 的缩写, scp 是 linux 系统下基于 ssh 登陆进行安全的远程文件拷贝命令。
scp 是加密的,rcp 是不加密的,scp 是 rcp 的加强版。

语法

参数说明:

  • -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)的选项。

实例

本地上传到远程服务器
scp /home/work/source.txt work@192.168.0.10:/home/work/
把本地的source.txt文件拷贝到192.168.0.10机器上的/home/work目录下

远程服务器下载到本地
scp work@192.168.0.10:/home/work/source.txt /home/work/
把192.168.0.10机器上的source.txt文件拷贝到本地的/home/work目录下

远程服务器拷贝到远程服务器
scp work@192.168.0.10:/home/work/source.txt work@192.168.0.11:/home/work/
把192.168.0.10机器上的source.txt文件拷贝到192.168.0.11机器的/home/work目录下

拷贝文件夹
scp -r /home/work/sourcedir work@192.168.0.10:/home/work/
拷贝文件夹,加-r参数

(1)将本地文件拷贝到远程
scp 文件名 用户名@计算机IP或者计算机名称:远程路径
本地192.168.1.8客户端
scp /root/install.* root@10.129.16.3:/usr/local/src

(2)从远程将文件拷回本地
scp 用户名@计算机IP或者计算机名称:文件名 本地路径
本地10.129.16.3客户端取远程服务器12、11上的文件
scp root@192.168.1.12:/usr/local/src/*.log /root/

2、复制文件夹(目录)

(1)将本地文件夹拷贝到远程
scp -r 目录名 用户名@计算机IP或者计算机名称:远程路径
scp -r /home/test1 username@192.168.0.1:/home/test2
scp -r /opt/
#test1为源目录,test2为目标目录,username@192.168.0.1为远程服务器的用户名和ip地址。

(2)从远程将文件夹拷回本地
scp -r 用户名@计算机IP或者计算机名称:目录名 本地路径
scp -r username@192.168.0.1:/home/test2 /home/test1
#username@192.168.0.1为远程服务器的用户名和ip地址,test1为源目录,test2为目标目录。_

说明

1.如果远程服务器防火墙有为scp命令设置了指定的端口,我们需要使用 -P 参数来设置命令的端口号,命令格式如下:
#scp 命令使用端口号 4588
scp -P 4588 remote@www.runoob.com:/usr/local/sin.sh /home/administrator
2.使用scp命令要确保使用的用户具有可读取远程服务器相应文件的权限,否则scp命令是无法起作用的。