您的位置:

Linux运维工程师必备:SCP文件传输命令使用方法

一、SCP命令概述

SCP是Secure Copy的缩写,它允许你远程拷贝文件。这个命令基于ssh协议,实现了可靠的文件传输。SCP可以在Linux系统间或Linux和Windows系统间复制文件、目录等。SCP不仅仅是能够复制本机中的文件到远程服务器中,还可以从远程服务器复制文件到本地。SCP还可以利用ssh的认证机制,避免了FTP和telnet的一些弱点。

二、scp命令语法

scp [-1246BCpqrv] [-c cipher] [-F ssh_config] [-i identity_file] [-l limit] [-o ssh_option] [-P port] [-S program] source_file target_file

说明:

  • -1: 强制scp命令使用协议ssh1
  • -2: 强制scp命令使用协议ssh2
  • -4: 强制scp命令只使用IPv4寻址
  • -6: 强制scp命令只使用IPv6寻址
  • -B: 以批处理模式运行,不询问传输口令和密钥
  • -C: 允许压缩。(由于网络原因,压缩后传输更快)
  • -p: 保留原文件的修改时间、访问时间和访问权限
  • -q: 不显示传输进度条。
  • -r: 递归复制整个目录。
  • -v: 显示详细的传输过程。
  • -c cipher: 以cipher将数据传输进行加密,这个选项通常不必指定。
  • -F ssh_config: 指定ssh配置文件。
  • -i identity_file: 从identity_file指定文件中读取传输时使用的密钥文件。
  • -l limit: 限定用户所能使用的带宽,以Kbit/s为单位。
  • -o ssh_option: 如果习惯于使用ssh_config(5)将选项写入配置文件中,这个选项可用于在命令行上设置选项。
  • -P port: 注意是大写的P,并且port是指定数据传输用到的端口号
  • -S program: 指定加密传输时所使用的程序

三、SCP命令实例

1. 从本地复制文件到远程服务器

scp /path/to/local/file user@remote:/path/to/remote/

比如,我们要将本地的/home/user/abc.txt文件复制到远程服务器的/tmp目录下,命令如下:

scp /home/user/abc.txt root@192.168.1.100:/tmp/

2. 从远程服务器复制文件到本地

scp user@remote:/path/to/remote/file /path/to/local/

比如,我们要将远程服务器的/tmp/abc.txt文件复制到本地的/home/user目录下,命令如下:

scp root@192.168.1.100:/tmp/abc.txt /home/user/

3. 从本地复制目录到远程服务器

scp -r /path/to/local/dir user@remote:/path/to/remote/

比如,我们要将本地的/home/user目录复制到远程服务器的/tmp目录下,命令如下:

scp -r /home/user root@192.168.1.100:/tmp/

4. 从远程服务器复制目录到本地

scp -r user@remote:/path/to/remote/dir /path/to/local/

比如,我们要将远程服务器的/tmp目录复制到本地的/home/user目录下,命令如下:

scp -r root@192.168.1.100:/tmp /home/user/

5. 使用非标准端口复制文件

scp -P port /path/to/local/file user@remote:/path/to/remote/

比如,我们要将本地的/home/user/abc.txt文件复制到远程服务器的/tmp目录下,并且使用22号端口,命令如下:

scp -P 22 /home/user/abc.txt root@192.168.1.100:/tmp/

6. 显示传输过程

scp -v /path/to/local/file user@remote:/path/to/remote/

比如,我们要将本地的/home/user/abc.txt文件复制到远程服务器的/tmp目录下,并且显示传输过程,命令如下:

scp -v /home/user/abc.txt root@192.168.1.100:/tmp/

7. 限制带宽

scp -l 512 /path/to/local/file user@remote:/path/to/remote/

比如,我们要将本地的/home/user/abc.txt文件复制到远程服务器的/tmp目录下,并且限制带宽为512Kbit/s,命令如下:

scp -l 512 /home/user/abc.txt root@192.168.1.100:/tmp/

8. 保留文件时间和权限

scp -p /path/to/local/file user@remote:/path/to/remote/

比如,我们要将本地的/home/user/abc.txt文件复制到远程服务器的/tmp目录下,并且保留原文件的修改时间、访问时间和访问权限,命令如下:

scp -p /home/user/abc.txt root@192.168.1.100:/tmp/

9. 使用ssh密钥

这里的id_rsa是你自己的密钥文件。

scp -i ~/.ssh/id_rsa /path/to/local/file user@remote:/path/to/remote/

比如,我们要将本地的/home/user/abc.txt文件复制到远程服务器的/tmp目录下,并且使用ssh密钥,命令如下:

scp -i ~/.ssh/id_rsa /home/user/abc.txt root@192.168.1.100:/tmp/

10. 使用不同的用户名和端口

scp -P port -r /path/to/local/dir differentuser@remote:/path/to/remote/

比如,我们要将本地的/home/user目录复制到远程服务器的/tmp目录下,使用22号端口并且另一个用户differentuser,命令如下:

scp -P 22 -r /home/user differentuser@192.168.1.100:/tmp/

四、总结

SCP是一个非常实用的命令,可以方便地进行文件传输。通过本文的实例,相信大家已经掌握了SCP命令的基本用法。大家可以根据自己的需求,结合实际情况,灵活使用SCP命令,达到高效、安全地进行文件传输的目的。