在开发项目过程中,难免会遇到需要上传一些文件或者服务器间复制一些文件的情况,例如有10G的压缩文件需要从 A 服务器传输到 B 服务器,实现方式有多种,例如可放到域名下远程下载,或者通过 sz 下载到本地再 rz 上传到 B 服务器等。这些方法若用在此场景下总感觉不太友好,所有现在讨论用到的是 scp 命令。
Linux scp命令用于Linux之间复制文件和目录。
scp是 secure copy的缩写, scp是linux系统下基于ssh登陆进行安全的远程文件拷贝命令。
参数说明:
- -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)的选项。
从远程复制到本地:
[root@2 web]# scp -r root@192.168.1.1:/web /web
enter后会提示输入远程的登陆密码,输入密码后enter就开始复制文件了。
从本地复制到远程,只需要调换一下两地址位置就可以了,还有一种情况就是使用密钥登陆,此时只需要将密钥文件参数带上:
[root@2 web]# scp -r -i xxx.pem /web root@192.168.1.1:/web
若在使用密钥登陆的情况下报错,提示依然要输入密码,此时只需要修改xxx.pem的权限为 600 即可解决:
[root@2 web]# scp -r -i xxx.pem /web root@192.168.1.1:/web
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
@ WARNING: UNPROTECTED PRIVATE KEY FILE! @
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
Permissions 0755 for 'xxx.pem' are too open.
It is required that your private key files are NOT accessible by others.
This private key will be ignored.
bad permissions: ignore key: xxx.pem
root@192.168.1.1's password:
#修改权限后再次执行传输命令即可
[root@2 web]# chmod 600 xxx.pem
使用scp在服务器间传输文件感觉非常方便,一句命令就操作完成了。