Linux之scp命令的使用

不问归期 提交于 2019-12-06 08:21:36

Linux之scp命令的使用

1. scp简介

1.1 命令功能:

scp是 secure copy的缩写, scp是linux系统下基于ssh登陆进行安全的远程文件拷贝命令。linux的scp命令可以在linux服务器之间复制文件和目录。

格式为:scp [可选参数] file_source file_target

1.2 命令参数

  • -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. 命令实践

主机名 IP地址 备注
web01 192.168.200.28 测试服务器(一)
web02 192.168.200.29 测试服务器(二)

2.1 将本机文件复制到远程服务器上

[root@web01 ~]# scp -r /root/test root@192.168.200.29:/tmp/

#命令详解:
/root            本地文件的绝对路径
test             要复制到服务器上的本地文件
root             通过root用户登录到远程服务器(也可以使用其他拥有同等权限的用户)
192.168.200.29   远程服务器的ip地址(也可以使用域名或机器名)
/tmp             将本地文件复制到位于远程服务器上的路径

2.2 将远程服务器上的文件复制到本机

[root@web01 ~]# scp -r root@192.168.200.29:/tmp/test /root/sc/

#命令详解:
root             通过root用户登录到远程服务器(也可以使用其他拥有同等权限的用户)
192.168.200.29   远程服务器的ip地址(也可以使用域名或机器名)
/tmp/test        欲复制到本机的位于远程服务器上的文件 
/root/sc/        将远程文件复制到本地的绝对路径

2.3 如果远程服务器防火墙有特殊限制,scp便要走特殊端口,具体用什么端口视情况而定,命令格式如下:

[root@web01 ~]# scp -rP 1234 /root/test root@192.168.200.29:/tmp/

2.4 scp命令延申

#对拷文件夹 (包括文件夹本身)
[root@web01 ~]# scp -r /root/sc root@192.168.200.29:/tmp/
#对拷文件夹下所有文件 (不包括文件夹本身)
[root@web01 ~]# scp -r /root/sc/* root@192.168.200.29:/tmp/
#对拷文件并重命名
[root@web01 ~]# scp -r /root/test root@192.168.200.29:/tmp/test.txt
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!