Linux系统中的scp(secure copy)命令用于以安全方式在服务器之间复制文件。通过使用SCP命令或安全副本,可以在本地主机和远程主机之间或两个远程主机之间安全地传输文件。它使用与安全外壳(SSH)协议中相同的身份验证和安全性。SCP以其简单性,安全性和预安装的可用性而闻名。
命令格式
scp [参数] [原路径] [目标路径]
命令参数
- -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)的选项。
复制当前目录下的rumenz.tar.gz
到远程服务器
> scp rumenz.tar.gz root@json.im:/tmp/rumenz.tar.gz
指定了用户名,命令执行后需要输入用户密码;如果不指定用户名,命令执行后需要输入用户名和密码;
复制rumenz
目录到远程服务器
> scp -r rumenz root@json.im:/tmp
复制目录需要加上
-r
参数
从远程服务器下载rumenz.tar.gz
文件到本地
> scp root@json.im:/tmp/rumenz.tar.gz ./tmp
从远程服务器下载rumenz
目录
> scp -r root@json.im:/tmp/rumenz .
自定义端口
SCP使用端口22作为默认端口。但是出于安全原因,您可以将端口更改为另一个端口。例如,我们将使用端口2222。那么命令必须像这样。
> scp -P 2222 rumenz.tar.gz root@json.im:/tmp/
限制带宽使用
-l
参数将限制要使用的总带宽。如果您制作了一个自动化脚本来复制许多文件,但是您不希望SCP进程浪费带宽,这将很有用。
> scp -l 400 rumenz.tar.gz root@json.im:/tmp/