1、scp命令
scp 是 secure copy 的缩写, scp 是 linux 系统下基于 ssh 登陆进行安全的远程文件拷贝命令。通常用于服务器之间文件传输。
usage: scp [-346ABCpqrTv] [-c cipher] [-F ssh_config] [-i identity_file]
[-J destination] [-l limit] [-o ssh_option] [-P port]
[-S program] source ... target
使用例子:
scp test.zip root@197.168.1.1:/data/
在这里输入服务器密码:
命令参数
- -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、scp免密传输文件
经常应用此场景会发现每次都需输入密码,操作有点繁琐啊。
graph TD
本地机器 --> 远程机器
例如有2个机器:本地(197.168.1.1)、远程(197.168.1.2)
2.1 生成秘钥(公钥、私钥)
ssh-keygen -t rsa
一直回车即可,在本地~/.ssh/目录生成id_rsa、id_rsa.pub文件。
- id_rsa: 私钥,这玩意不能给别人
- id_rsa.pub: 公钥,这玩意可以给到远程服务器,用于免密登录。
2.2 上传本地生成的id_rsa.pub文件到远程服务器
scp id_rsa.pub root@197.16.8.1.2:/root/.ssh/id_rsa.pub
输入密码,完成上传。
2.3、在远程服务器B上将复制过来的id_rsa.pub文件**
- 2.3.1 如果/root/.ssh/下已存在authorized_keys文件
cat id_rsa.pub >> authorized_keys
- 如果/root/.ssh/下不存在authorized_keys文件
mv id_rsa.pub authorized_keys
2.4 测试
此时两台机器已建立信任关系了,本地到远端即可以实现免密传输了,如果要实现远端到本地免密传输,操作是一样的,也可以把source、target 互换实现远端到本地的传输。
3. 从本地复制到远端
scp local_file remote_username@remote_ip:remote_folder
或者
scp local_file remote_username@remote_ip:remote_file
或者
scp local_file remote_ip:remote_folder
或者
scp local_file remote_ip:remote_file
- 第1,2个指定了用户名,命令执行后需要再输入密码,第1个仅指定了远程的目录,文件名字不变,第2个指定了文件名;
- 第3,4个没有指定用户名,命令执行后需要输入用户名和密码,第3个仅指定了远程的目录,文件名字不变,第4个指定了文件名;
应用实例:
scp 1.mp3 root@197.168.1.2:/data/1.mp3
scp 1.mp3 root@197.168.1.2:/data
scp 1.mp3 root@197.168.1.2:/data/001.mp3
复制目录命令格式:
scp -r local_folder remote_username@remote_ip:remote_folder
或者
scp -r local_folder remote_ip:remote_folder
- 第1个指定了用户名,命令执行后需要再输入密码;
- 第2个没有指定用户名,命令执行后需要输入用户名和密码;
应用实例:
scp -r /data/test root@197.168.1.2:/data/test
上面命令将本地 test 目录复制到远程 test 目录下。
4、从远程复制到本地
从远程复制到本地,只要将从本地复制到远程的命令的后2个参数调换顺序即可,如下实例
应用实例:
scp root@197.168.1.2:/data/1.mp3 /data/1.mp3
scp -r root@197.168.1.2:/data/test/ /data