scp命令

147 阅读3分钟

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