linux远程拷贝文件命令(从别的服务器复制文件的步骤)


在开发中经常遇到这样的场景,就是两台Linux服务器间需要互相拷贝文件。常见的场景就是在本机通过堡垒机才能登录到远程的Linux服务器上,而堡垒机上没有相应的ftp可视化工具;这时就需要借助远程拷贝命令。

scp就是secure copy,在linux下用来进行远程拷贝文件的命令。有时需要获得远程服务器上的某个文件,该服务器既没有配置ftp服务器,也没有做共享,无法通过常规途径获得文件时,只需要通过简单的scp命令便可达到目的。

语法:

scp [-1246BCpqrv] [-c cipher] [-F ssh_config] [-i identity_file]
[-l limit] [-o ssh_option] [-P port] [-S program]
[[user@]host1:]file1 [...] [[user@]host2:]file2

参数:

  • -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)的选项。

0x01:将本机文件复制到远程服务器上

#scp /home/oracle/news.txt root@192.168.6.129:/tmp

分析:

/home/oracle/ :本地文件的绝对路径

news.txt :要复制到服务器上的本地文件

root:通过root用户登录到远程服务器(也可以使用其他拥有同等权限的用户)

192.168.6.129:远程服务器的ip地址(也可以使用域名或机器名)

/tmp:将本地文件复制到位于远程服务器上的路径

0x02: 将远程服务器上的文件复制到本机

#scp remote@www.itpk.com:/usr/local/sin.sh /home/oracle

remote:通过remote用户登录到远程服务器(也可以使用其他拥有同等权限的用户)

www.itpk.com:远程服务器的域名(当然也可以使用该服务器ip地址)

/usr/local/sin.sh:欲复制到本机的位于远程服务器上的文件

/home/oracle:将远程文件复制到本地的绝对路径

0x03:需要注意两点

  • 如果远程服务器防火墙有特殊限制,scp便要走特殊端口,具体用什么端口视情况而定,命令格式如下:
#scp -p 4588 remote@www.itok.com:/usr/local/sin.sh /home/oracle
  • 使用scp要注意所使用的用户是否具有可读取远程服务器相应文件的权限。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发表评论

登录后才能评论