Linux 两台服务器之间传输文件和文件夹四种方式

在日常服务器租用中,有时需要将文件从一台服务器传到另一台服务器,下面给大家介绍四种linux服务器之间传输文件方式。

  1. scp
  • 【优点】简单方便,安全可靠;支持限速参数
  • 【缺点】不支持排除目录
  • 【用法】scp就是secure copy,是用来进行远程文件拷贝的。数据传输使用 ssh,并且和ssh 使用相同的认证方式,提供相同的安全保证 。

命令格式:scp [参数] <源地址(用户名@IP地址或主机名)>:<文件路径>   <目的地址(用户名 @IP 地址或主机名)>:<文件路径>

 假设远程服务器IP地址为 192.168.1.100

1)从服务器复制文件到本地:

scp root@192.168.1.100:/data/test.txt /home/myfile/
root@192.168.1.100   root是目标服务器(有你需要拷贝文件的服务器)的用户名,

192.168.1.100是IP地址,后面紧跟的 “:” 不要忘记

路径1: /data/test.txt 是目标服务器中你要拷贝文件的地址,接一个空格

路径2:  /home/myfile/ 是本地接收文件的地址。

2)复制文件到本地并重命名:

scp /home/myfile/test.txt  root@192.168.1.100:/data/testxxx.txt

3)从服务器复制文件夹到本地:

scp -r root@192.168.1.100:/data/  /home/myfile/
只需在前面加 -r 即可,就可以拷贝整个文件夹。

4)从本地复制文件到服务器(不包括文件夹本身)

scp /home/myfile/test.txt  root@192.168.1.100:/data/

scp /home/myfile/*  root@192.168.1.100:/data/

5)从本地复制文件夹到服务器(包括文件夹本身)

scp -r /home/myfile/ root@192.168.1.100:/data/

 2.rcp
【概述】

目标主机需要事先打开rcp功能,并设置好rcp的权限:把源主机加入到可信任主机列表中,否则无法在源主机上使用rcp远程复制文件到目标主机。

rcp部分摘自:rcp命令_William234的博客-CSDN博客_rcp命令

rcp代表“remote file copy”(远程文件拷贝)。该命令用于在计算机之间拷贝文件。rcp命令有两种格式。第一种格式用于文件到文件的拷贝;第二种格式用于把文件或目录拷贝到另一个目录中。


1.命令格式:rcp [参数] [源文件] [目标文件]

2.命令功能:
rcp命令用在远端复制文件或目录,如同时指定两个以上的文件或目录,且最后的目的地是一个已经存在的目录,则它会把前面指定的所有文件或目录复制到该目录中。
3.命令参数:
各选项含义:
-r 递归地把源目录中的所有内容拷贝到目的目录中。要使用这个选项,目的必须是一个目录。
-p 试图保留源文件的修改时间和模式,忽略umask。
-k 请求rcp获得在指定区域内的远程主机的Kerberos 许可,而不是获得由krb_relmofhost⑶确定的远程主机区域内的远程主机的Kerberos许可。
-x 为传送的所有数据打开DES加密。这会影响响应时间和CPU利用率,但是可以提高安全性。如果在文件名中指定的路径不是完整的路径名,那么这个路径被解释为相对远程机上同名用户的主目录。如果没有给出远程用户名,就使用当前用户名。如果远程机上的路径包含特殊shell字符,需要用反斜线(\\)、双引号(”)或单引号(’)括起来,使所有的shell元字符都能被远程地解释。需要说明的是,rcp不提示输入口令,它通过rsh命令来执行拷贝。
directory 每个文件或目录参数既可以是远程文件名也可以是本地文件名。远程文件名具有如下形式:rname@rhost:path,其中rname是远程用户名,rhost是远程计算机名,path是这个文件的路径。


4.使用实例:
要使用 rcp,需要具备以下条件:
如果系统中有 /etc/hosts 文件,系统管理员应确保该文件包含要与之进行通信的远程主机的项。

/etc/hosts 文件中有一行文字,其中包含每个远程系统的以下信息:
internet_address   official_name   alias

例如:

9.186.10.***  webserver1.com.58.webserver

.rhosts 文件
.rhosts 文件位于远程系统的主目录下,其中包含本地系统的名称和本地登录名。


例如,远程系统的 .rhosts 文件中的项可能是:webserver1 root

其中,webserver1 是本地系统的名称,root 是本地登录名。这样,webserver1 上的 root 即可在包含 .rhosts 文件的远程系统中来回复制文件。

配置过程:只对root用户生效

1. 在双方root用户根目录下建立.rhosts文件,并将双方的hostname加进去.在此之前应在双方的 /etc/hosts文件中加入对方的IP和hostname

2. 把rsh服务启动起来,redhat默认是不启动的。

方法:用执行ntsysv命令,在rsh选项前用空格键选中,确定退出。然后执行:

service xinetd restart即可。

3. 到/etc/pam.d/目录下,把rsh文件中的auth required /lib/security/pam_securetty.so

一行用“#”注释掉即可。(只有注释掉这一行,才能用root用户登录)


命令使用:
将文件复制到远程系统
要将本地系统中的文件复制到远程系统,请使用以下命令:
rcp   local_file   remote_hostname:remote_fileEnter

注意,如果当前目录下没有 local_file,则除本地文件名外,还需要提供相对路径(自当前目录开始)或绝对路径名(自 / 开始)。
仅当希望将 remote_hostname 上的 remote_file 放到其他目录(远程主目录除外)下时,才需要为其指定完整的(绝对)路径。

使用实例1:将当前目录下的 test1 复制到名为 webserver1的远程系统
命令:
rcp  test1   webserver1:/home/root/test3

说明:
在这种情况下,test1 被复制到远程子目录 test3下,名称仍为 test1 。如果仅提供了远程主机名,rcp 将把 test1 复制到远程主目录下,名称仍为 test1 。
还可以在目的目录中包含文件名。例如,将文件复制到名为 webserver1的系统中:

rcp test1 webserver1:/home/root/test3
在这种情况下,将 test1 复制到远程目录root 下并将其命名为 test3。

使用实例2:从远程系统复制文件:要将远程系统中的文件复制到本地目录下命令:

rcp remote_hostname:remote_file local_fileEnter
使用实例:3:将远程系统 webserver1中的 test2 复制到当前目录:

命令:

rcp webserver1:/home/root/test2 .Enter

说明:
点 (.) 是“当前目录”的简写形式。在这种情况下,远程目录中的 test2 被复制到当前目录下,名称仍为 test2 。
如果希望用新名称复制文件,请提供目标文件名。
如果希望将 test2 复制到本地系统中的其他目录下,请使用以下绝对或相对路径名:
rcp webserver1:/home/root/test2 otherdir/ Enter
或者,如果希望用其他文件名将文件复制到其他目录下:
rcp webserver1:/home/root/test2 otherdir/otherfile Enter

使用实例4:将目录复制到远程系统:要将本地目录及其文件和子目录复制到远程系统,请同时使用 rcp 和 -r(递归)选项。

命令:

rcp –r   local_dir   remote_hostname:remote_dir Enter
说明:
如果当前目录下没有 local_dir,则除本地目录名外,还需要提供相对路径名(自当前目录开始)或绝对路径名(自 / 顶级目录开始)。另外,如果主目录下没有 remote_dir,则 remote_dir 将需要一个相对路径(自主目录开始)或绝对路径(自 / 开始)。

使用实例5:
要将名为 work 的子目录完整地复制到 webserver1远程计算机中的主目录下名为 products 的目录,请键入以下内容:
rcp –r work  webserver1:/home/root/products Enter

此命令在 webserver1:/home/root/products 下创建名为 work 的目录及其全部内容(假定 /home/root/products 已存在于 webserver1中)。
本示例假定用户处于包含 work 的本地目录下。否则,必须提供该目录的相对或绝对路径,如 /home/root/work。

使用实例6:从远程系统复制目录:
要将远程目录及其所有文件和子目录复制到本地目录,请在以下语法中使用 rcp 和 -r(递归)选项。
命令:
rcp –r remote_hostname:remote_dir local_dir Enter
要将名为 work 的远程目录复制到当前目录,请键入以下内容:
rcp –r webserver1:/home/root/work .Enter
点 (.) 表示当前目录。将在此目录下创建 work 目录。

3.wget
【优点】简单方便,支持排除目录,支持限速参数

【缺点】只能从远程机器将文件或文件夹下载到本地,并且远程机器需要支持ftp服务(例如启动proftpd);参数较多,使用上比scp复杂

【用法】

wget是一个从网络上自动下载文件的自由工具,支持通过HTTP、HTTPS、FTP三个最常见的TCP/IP协议下载,并可以使用HTTP代理。

命令格式:

wget [参数] ftp://<目标机器ip或主机名>/<文件的绝对路径>   #proftpd格式

举例:

wget ftp://192.168.0.10//home/work/source.txt    #从192.168.0.10上拷贝文件夹source.txt

wget ftp://www.myhost.com//home/work/source.txt       #使用主机名

wget -nH -P /home/work/  ftp://www.myhost.com//home/work/source.txt

#指定本地保存路径,使用参数“-P 路径”或者“–directory-prefix=路径”;-nH, --no-host-directories 不创建主机目录

wget -r -l 0 -nH -P /home/work/ ftp://www.myhost.com//home/work/sourcedir

#递归下载sourcedir目录,使用参数-r;参数-l, --level=NUMBER 最大递归深度 (inf 或 0 代表无穷).

wget --cut-dirs=3 -r -l 0 -nH -P /home/work/ ftp://www.myhost.com//home/work/sourcedir

#-参数-cut-dirs=NUMBER 忽略 NUMBER层远程目录,本例中将myhost上的sourcedir目录保存到本地的work目录下。

wget --limit-rate=200k --cut-dirs=3 -r -l 0 -nH -P /home/work/ ftp://www.myhost.com//home/work/sourcedir #-参数–limit-rate=RATE 限定下载输率

wget --limit-rate=200k --cut-dirs=3 -r -l 0 -nH -P /home/work/ -X /home/work/sourcedir/notincludedir ftp://www.myhost.com//home/work/sourcedir #排除路径使用-X参数

wget -q --limit-rate=200k --cut-dirs=3 -r -l 0 -nH -P /home/work/ -X /home/work/sourcedir/notincludedir ftp://www.myhost.com//home/work/sourcedir #参数-q表示安静模式,无输出;默认是-v,冗余模式

4.rsync
【优点】功能强大,操作类似scp,支持排除目录,支持限速参数;还支持本地复制。

【缺点】暂无

【用法】rsync是类unix系统下的数据镜像备份工具,从软件的命名上就可以看出来了——remote sync。它的操作方式和scp和相似,但是比scp强大很多。使用双冒号分割主机名和文件路径时,是使用rsync服务器,这里不做介绍。

命令格式:

rsync [参数] <源地址(用户名@IP地址或主机名)>:<文件路径> <目的地址(用户名 @IP 地址或主机名)>:<文件路径>

举例:

rsync /home/work/source.txt work@192.168.0.10:/home/work/

#把本地的source.txt文件拷贝到192.168.0.10机器上的/home/work目录下

rsync work@192.168.0.10:/home/work/source.txt /home/work/

#把192.168.0.10机器上的source.txt文件拷贝到本地的/home/work目录下

rsync work@192.168.0.10:/home/work/source.txt work@192.168.0.11:/home/work/

#把192.168.0.10机器上的source.txt文件拷贝到192.168.0.11机器的/home/work目录下

rsync -r /home/work/sourcedir work@192.168.0.10:/home/work/

#拷贝文件夹,加-r参数

rsync -r /home/work/sourcedir work@www.myhost.com:/home/work/ #使用主机名

rsync -r -v /home/work/sourcedir work@www.myhost.com:/home/work/ #显示详情,加-v参数

rsync -r -v --exclude sourcedir/notinclude /home/work/sourcedir work@www.myhost.com:/home/work/ #排除子目录

注意:–exclude后面的路径不能为绝对路径,必须为相对路径才可以,否则匹配不上,就不会被排除掉。

<think>好的,我现在需要帮用户解决如何在两台Linux服务器之间使用scp命令进行文件传输测试的问题。首先,我得回忆一下scp的基本用法相关参数。根据用户提供的引用内容,特别是引用[5]中的例子,scp的基本格式是scp [参数] 源文件 目标路径。用户可能需要知道如何传输单个文件、多个文件或者整个文件夹。 接下来,我得考虑用户可能的测试场景。比如,他们可能需要从本地复制到远程,或者反过来。引用[3]提到使用端口号的情况,所以应该包括指定端口的方法。外,用户可能需要递归传输文件夹,这时候需要用到-r参数,引用[3]虽然例子中没有-r,但通常传输文件夹需要这个参数,可能需要确认是否正确。 然后,关于权限SSH配置的问题。引用[2]提到有些服务器可能没有安装scp,这时候需要安装openssh-clients,这可能是一个常见问题,用户在进行测试前需要确保scp已安装。同时,引用[3]提到无需密码验证,可能涉及到SSH密钥对配置,这也是测试中可能需要用到的,特别是自动化传输时。 外,用户可能想知道如何测试传输速度,引用[4]中的命令涉及到了速度测试,可能需要解释如何通过添加-v参数来获取详细输出,或者使用其他工具如rsync进行更高效的传输,但用户明确问的是scp,所以应该集中在scp的参数上。 还需要注意安全性,scp基于SSH,所以默认是加密的,但用户可能关心是否会有权限问题,比如目标路径的写入权限,这需要提醒用户检查目录权限。 最后,生成相关问题时要覆盖常见问题,比如性能优化、权限问题、断点续传等,以及替代方案如rsync,这样用户如果有进一步需求可以自行探索。 总结步骤应该是先安装scp,确保SSH连通,然后使用不同的命令格式进行文件传输测试,包括指定端口、递归传输,最后验证文件完整性。同时提醒常见问题错误处理,比如权限安装问题。</think>### 分步说明:两台Linux服务器之间使用SCP进行文件传输测试 --- #### **1. 确认环境准备** - **安装SCP工具**: 若服务器未安装`scp`,需安装`openssh-clients`包: ```bash yum install openssh-clients # CentOS/RHEL apt-get install openssh-client # Ubuntu/Debian ``` 引用[2]提到某些服务器默认未安装`scp`,需手动安装[^2]。 - **SSH连通性验证**: 确保两台服务器可通过SSH互相登录(建议配置SSH密钥对实现免密传输[^3])。 --- #### **2. 基础文件传输命令** - **从本地复制到远程服务器**: ```bash scp /本地路径/文件.txt 用户名@远程IP:/目标路径/ ``` 示例(引用[5]): ```bash scp /home/myfile/test.txt root@192.168.1.100:/data/ [^5] ``` - **从远程复制到本地服务器**: ```bash scp 用户名@远程IP:/远程路径/文件.txt /本地目标路径/ ``` - **指定SSH端口**(若非默认22端口): ```bash scp -P 端口号 文件路径 用户名@IP:/目标路径/ ``` --- #### **3. 文件夹传输测试** - 使用 `-r` 参数递归传输整个目录: ```bash scp -r /本地文件夹/ 用户名@远程IP:/目标路径/ ``` --- #### **4. 测试传输性能与日志** - **显示传输进度与速度**: 添加 `-v` 参数输出详细日志(引用[4]): ```bash scp -v 文件路径 用户名@IP:/目标路径/ 2>&1 | grep "Speed" ``` - **限速测试**(避免带宽占满): ```bash scp -l 1000 文件路径 用户名@IP:/目标路径/ # 限速1000 Kb/s ``` --- #### **5. 验证文件完整性** 传输完成后,通过校验文件哈希值确认一致性: ```bash md5sum 本地文件.txt ssh 用户名@远程IP "md5sum /目标路径/文件.txt" ``` --- ### § 常见问题与注意事项 § 1. **权限不足**: 目标路径需有写入权限,否则会报错 `Permission denied`。 2. **防火墙或SSH配置限制**: 确保两台服务器的SSH端口(默认22)在防火墙中放行。 3. **大文件传输中断**: SCP不支持断点续传,若需稳定性建议改用 `rsync`。 --- ### §§ 相关问题 §§ 1. 如何配置SSH密钥对实现SCP免密传输? 2. SCP传输文件时如何避免超时中断? 3. SCPrsync在文件传输中的主要区别是什么? 4. 如何通过SCP传输文件时跳过已存在的文件? 5. SCP传输速度受哪些因素影响?如何优化? --- 以上步骤覆盖了基础测试、性能验证错误排查,可满足大多数传输测试需求。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值