Linux这么在两个服务器直接传文件?

概念

scp是secure copy的简写, 是 linux 系统下基于 ssh 登陆进行安全的远程文件拷贝命令。scp 是加密的,rcp 是不加密的,scp 是 rcp 的加强版。

因为scp传输是加密的,可能会稍微影响一下速度。另外,scp还非常不占资源,不会提高多少系统负荷,在这一点上,rsync就远远不及它了。虽然 rsync比scp会快一点,但当小文件众多的情况下,rsync会导致硬盘I/O非常高,而scp基本不影响系统正常使用。

场景:假设我现在有两台服务器(这里的公网ip和内网ip相互传都可以,当然用内网ip相互传比较快,**公网ip不便公布)

Sessions1: 47.95.208.2**
内网:172.17.31.174
User:root
Sessions2: 47.94.92.2**
内网:172.17.31.173
User:root

这里常用的两种办法:

1.当从一个远程服务器传输文件到另一个服务器上(你想传给别人文件)

现在我们登录172.17.31.173这台服务器,想把当前的test.mysql传给别人(172.17.31.174这台服务器)
hostname -i 可以查看当前ip
在这里插入图片描述

在这里插入图片描述
命令:scp test.sql root@172.17.31.174:/data/
如果两台服务器直接没有配置免密登录的话需要输入密码。
在这里插入图片描述
这里的ip我用的是内网ip,所以传的快点儿,走公网的话就慢很多(亲测)
传输完成!
在ip为后缀174的服务器查看一下:
在这里插入图片描述

附录:
scp [可选参数] file_source file_target

常用的-r,-C

-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.在本地服务器,从另一个服务器中获取文件(你想从别人获取文件)

在173服务data目录中新建一个local_test 用来测试文件夹(测试-r参数的)
在这里插入图片描述
然后转到本地服务器(*174这一台),这里的本地服务器是相对的。
命令:scp -r root@172.17.31.173:/data/local_test /data/
在这里插入图片描述
拷贝文件夹则需要在scp后面加上-r
大白话描述:scp root@远程的服务器Ip:文件路径 存放路径

总结

在远程服务器上拷贝到本地服务器(登录远程服务器传给别人(本地)文件文件)
命令:scp test.sql root@172.17.31.174:/data/
需要别人(本地)的ip地址传输
在本地服务器登录,从远程服务器获取文件(自己主动去别人哪里获取文件)
命令:scp -r root@172.17.31.173:/data/local_test /data/
需要远程ip(别人)地址获取文件

  • 8
    点赞
  • 40
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
如果两台Linux服务器之间需要进行文件复制,且两台服务器SSH连接需要密码验证,可以使用以下脚本: ``` #!/bin/bash # 定义源文件和目标文件路径 source_path="/path/to/source/file" target_path="/path/to/target/directory" # 定义远程服务器的IP地址和用户名 remote_ip="remote_server_ip" remote_user="remote_server_user" # 复制文件到远程服务器 scp "$source_path" "$remote_user@$remote_ip:$target_path" # 输出复制成功信息 echo "File copied successfully!" ``` 在脚本中,需要指定远程服务器的IP地址和用户名。然后使用scp命令将文件复制到远程服务器上。当脚本运行时,会提示输入远程服务器的密码进行验证,验证成功后文件就会复制到远程服务器上。 如果需要复制多个文件,只需要修改脚本中的源路径和目标路径即可。如果需要将多个文件复制到同一个目标路径下,可以将目标路径设置为目录路径,然后使用`*`通配符来复制所有文件,例如: ``` #!/bin/bash # 定义源文件和目标文件路径 source_path="/path/to/source/*" target_path="/path/to/target/directory/" # 定义远程服务器的IP地址和用户名 remote_ip="remote_server_ip" remote_user="remote_server_user" # 复制文件到远程服务器 scp $source_path "$remote_user@$remote_ip:$target_path" # 输出复制成功信息 echo "Files copied successfully!" ``` 在这个例子中,`$source_path`是一个目录路径,可以使用`*`通配符来匹配该目录下的所有文件。然后将这些文件复制到远程服务器上的`$target_path`目录下。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值