从linux系统传输文件,Linux系统之间拷贝文件的方法总结

从linux系统传输文件目录

从linux系统传输文件

Linux系统之间拷贝文件的方法总结

linux下拷贝文件用什么命令?

linux下 两个连到路由器的服务器 怎么把一个服务器的文件传送到另一个服务器?

从linux系统传输文件

有几种方法可以在Linux系统中传输文件:。

1. 使用SCP(Secure Copy)命令:SCP命令可以在本地和远程主机之间进行安全的文件传输。命令的基本语法如下:。

```。

scp [选项] [源文件] [目标位置]。

```。

例如,将本地的文件file.txt传输到远程服务器的目录/home/user/下:。

```。

scp file.txt remoteuser@remotehost:/home/user/。

```。

2. 使用SFTP(Secure File Transfer Protocol)客户端:SFTP是一种在SSH上运行的文件传输协议。可以使用命令行工具(如OpenSSH的sftp命令)或者图形化的SFTP客户端(如FileZilla)来进行文件传输。。

3. 使用rsync命令:rsync命令可以实现本地文件和远程主机之间的同步和备份。它可以通过SSH连接进行文件传输,保证传输的安全性。基本的rsync命令语法如下:。

```。

rsync [选项] [源文件/目录] [目标位置]。

```。

例如,将本地目录dir传输到远程服务器的目录/home/user/下:。

```。

rsync -avz dir/ remoteuser@remotehost:/home/user/。

```。

4. 使用FTP(File Transfer Protocol):FTP是一种标准的文件传输协议,可以通过命令行工具(如ftp命令)或者图形化的FTP客户端来进行文件传输。需要注意的是,FTP传输没有加密,可能存在安全风险。。

以上方法中,使用SCP或者SFTP进行文件传输是较为安全和常用的方式。。

Linux系统之间拷贝文件的方法总结

首先,无论本地还是远程,需要移动或拷贝的文件较多且都不太大时,用cp命令和mv命令效率较低,可以先使用tar工具对将要拷贝/移动的内容进行打包/压缩,之后再进行拷贝/移动,最后再解包/解压缩。

另外,也是很关键的一个技巧,即,不必在tar打包/压缩完毕之后再进行拷贝,解包/解压缩,可以通过管道一边打包/压缩另一边执行拷贝解包/解压缩。

比如,tar命令可以和nc命令结合可以快速在两台机器之间传输文件和目录:

B机器:

nc -l 5555 |tar -C /tmp/test/ -xf -

A机器:

tar cf - /tmp/test/ |nc BIP 5555

上述步骤将A机器/tmp/test/下的内容拷贝到B机器对应的目录中,其中tar cf - /tmp/test/ |nc BIP 5555 将内容边打包边通过管道和nc命令传输到由对应IP地址和5555端口传到B机器,nc -l 5555 |tar -C /tmp/test/ -xf - 监听本机的555端口,并将接收到的内容解包至指定的目录(-C参数指定目标目录)

此外,tar还可与scp、ssh命令结合:

在A机打包后,复制到B机器并解包

tar -cf - /tmp/test | ssh BIP cd /tmp; tar -xf -

在A机打包,并将打包好的文件复制到B机

tar -cf - /tmp/test | ssh BIP cd /tmp; cat - test.tar

tar -cf - /tmp/test | scp - BUSER@BIP:/tmp

将A机的打包文件,复制到B机并解包

zcat test.tar | ssh BIP cd /tmp; tar -xf -

也可以直接在本地这么使用:

cd /tmp/test1

tar -cf - . | (cd /tmp/test2 ; tar -xvpf -)

但有人试验后得出结论本地直接用cp较快

另外一些小技巧:

拷贝时除了拷贝单个文件还会拷贝目录,有时需要连同文件/目录的属性一同拷贝。

可以在cp命令中使用-R参数递归拷贝目录,使用-p参数拷贝文件保留属性(默认是:mode,ownership,timestamps也可以通过 --preserve[=ATTR_LIST]指定要特别保留的属性如:context, links,xattr, all),使用-d参数拷贝文件保留连接。

或者简单的使用-a参数(相当于使用-dR --preserve=all)

如果想看到拷贝大量小文件的进度可以写一个简单的小脚本:

代码如下:

cd /tmp/test

for i in *

do

cp $i 目标目录

echo $i is ok....

done

最后补充一条不是技巧的技巧:在使用一个工具完成一项任务之前,先思考当前用的工具是不是最适合的工具?有没有更好的工具或办法?如果工具确实很适用于当前任务,那么在使用该工具时有没有特殊的技巧可以提高工作效率?(通常,查看帮助文档可有意外收获)。

linux下拷贝文件用什么命令?

cp命令 该命令的功能是将给出的文件或目录拷贝到另一文件或目录中,就如同DOS下的copy命令一样,功能非常强大。

语法: cp [选项] 源文件或目录 目标文件或目录 说明:该命令把指定的源文件复制到目标文件或把多个源文件复制到目标目录中。

该命令的各选项含义如下: - a 该选项通常在拷贝目录时使用。

- f 删除已经存在的目标文件而不提示。

- i 和f选项相反,在覆盖目标文件之前将给出提示要求用户确认。

回答y时目标文件将被覆盖,是交互式拷贝。

- p 此时cp除复制源文件的内容外,还将把其修改时间和访问权限也复制到新文件中。

- r 若给出的源文件是一目录文件,此时cp将递归复制该目录下所有的子目录和文件。

此时目标文件必须为一个目录名。

需要说明的是,为防止用户在不经意的情况下用cp命令破坏另一个文件,如用户指定的目标文件名是一个已存在的文件名,用cp命令拷贝文件后,这个文件就会被新拷贝的源文件覆盖,因此,建议用户在使用cp命令拷贝文件时,最好使用i选项。

$ cp - i exam1.c /usr/wang/shiyan1.c 该命令将文件exam1.c拷贝到/usr/wang 这个目录下,并改名为 shiyan1.c。

若不希望重新命名,可以使用下面的命令: $ cp exam1.c /usr/ wang/ $ cp - r /usr/xu/ /usr/liu/ 将/usr/xu目录中的所有文件及其子目录拷贝到目录/usr/liu中。

linux下 两个连到路由器的服务器 怎么把一个服务器的文件传送到另一个服务器?

scp就是security copy,用于将文件或者目录从一个Linux系统拷贝到另一个Linux系统下

scp传输数据用的是SSH协议,保证了数据传输的安全

其格式如下:scp 远程用户名@IP地址:文件的绝对路径 本地Linux系统路径 scp 本地Linux系统文件路径

远程用户名@IP地址:远程系统文件绝对路径名scp使用第一种格式是将远程Linux系统上的某个文件或者目录拷贝到本地Linux系统上来

使用第二种是将本地的某个文件或者目录拷贝到远程Linux系统的某个路径下

举例(1)目前我们处在IP为“192.168.60.133”的Linux系统下

计划将系统下的/home/ixdba/etc.tar.gz文件拷贝到IP为“192.168.60168”的远程Linux系统中root用户下的/tmp目录下:scp /home/ixdba/etc.tar.gz root@192.168.60.168:/tmp命令输入完毕

会要求输入“192.168.60.168”服务器root的密码,然后开始远程拷贝数据

如果我们处在“192.168.60.168”服务器上,也可以使用下面的命令传输数据:scp root@192.168.60.133:/home/ixdba/etc.tar.gz /tmp命令输入完毕,此时会要求输入“192.168.60.133”服务器root的密码,然后开始远程拷贝数据

(2)将本地/etc目录中所有的文件和子目录拷贝到IP为“192.168.60.135”的远程Linux系统的root用户下的/opt目录中:scp -r /etc root@192.168.60.135:/opt这里的选项“r”与cp命令的“r”选项含义相同

(随机推荐阅读本站500篇优秀文章点击前往:500篇优秀随机文章)
来源:本文由易搜IT博客原创撰写,欢迎分享本文,转载请保留出处和链接!