杂集:浅谈关于linux中的scp命令,附有案例

scp:secure copy的缩写, scp是linux系统下基于ssh登陆进行安全的远程文件拷贝命令。

scp命令用于Linux之间复制文件和目录。和它类似的命令有cp,不过cp只是在本机进行拷贝不能跨服务器,而且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 [参数] file_source file_target

2、scp [参数] [源路径] @IP:/目标路径

查看参数:

man scp

杂集:浅谈关于linux中的scp命令,附有案例

详细信息请参考help

杂集:浅谈关于linux中的scp命令,附有案例

参数解释:

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

在虚拟机中模拟

192.168.102.22 [本地机]

192.168.102.110 [远程机]

一、从本地机复制到远程机

1、文件的操作

方式1:

scp local_file remote_username@remote_ip:remote_folder/file[目录/文件]

方式2:

scp local_file remote_ip:remote_folder/file[目录/文件]

2、目录的操作

方式1:

scp -r local_folder remote_username@remote_ip:remote_folder

方式2:

scp -r local_folder remote_ip:remote_folder

注意:

方式1:命令执行后需要输入指定用户的密码。

方式2:命令执行后需要输入用户名和密码。

模拟测试:

在192.168.102.22[本地机]普通用户odysee家目录中

1、 创建一个scpLocal文件夹

2、 在文件夹中创建一个local文件

3、在文件local中输入'hello scp!'

杂集:浅谈关于linux中的scp命令,附有案例

在192.168.102.110[远程机]普通用户odysee家目录中

1、创建一个scpRemote

杂集:浅谈关于linux中的scp命令,附有案例

测试:

方式1:

scp local_file remote_username@remote_ip:remote_folder

把22的local文件copy到110 scpRemote/下面

scp local [email protected]:/home/odysee/scpRemote

输入密码后执行成功

杂集:浅谈关于linux中的scp命令,附有案例

查看远程机是否存在

杂集:浅谈关于linux中的scp命令,附有案例

方式2:

scp local_file remote_ip:remote_folder/file

把22的local2文件copy到110 scpRemote/下面

scp local2 192.168.102.110:/home/odysee/scpRemote

杂集:浅谈关于linux中的scp命令,附有案例

查看远程机110

杂集:浅谈关于linux中的scp命令,附有案例

关于对目录的操作和文件类似

下面模拟一个:

1、 在本地机的scpLocal/创建一个scpLocal2文件

2、 在scpLocal2/创建一个local3文件并写入'hello scp3!'

杂集:浅谈关于linux中的scp命令,附有案例

测试:

我们把本地机的scpLocal copy到远程机的scpRemote/

注意-r递归copy

scp -r local_folder remote_username@remote_ip:remote_folder

即:

scp -r scpLocal [email protected]:/home/odysee/scpRemote

注意执行命令所在目录

杂集:浅谈关于linux中的scp命令,附有案例

查看远程机

杂集:浅谈关于linux中的scp命令,附有案例

成功

2、 从远程机复制到本地机

相似于本地复制到远程机[把两个地址调换一下]

1、scp [参数] file_target file_source

2、scp [参数] @IP:/目标路径 [源路径]

如下:

1、文件的操作

Scp remote_username@remote_ip:remote_folder/file local_file

scp remote_ip:remote_folder/file local_file

2、目录的操作

scp -r remote_username@remote_ip:remote_folder local_folder

scp -r remote_ip:remote_folder local_folder

模拟一个:

把远程机的scpRemote复制到本地机的scpLocal/

scp -r [email protected]:/home/odysee/scpRemote scpLocal

杂集:浅谈关于linux中的scp命令,附有案例

测试成功

注意:

如远程服务器防火墙为scp命令设置指定端口,我们需要使用-P来设置命令端口号

如下:

scp -P port[端口号] remote_username@remote_ip:remote_file local_folder

小提示:

远程复制文件或者目录还需要来回的输入用户或则密码,可能稍微有点麻烦。

下一篇配置ssh免密码登录,再使用scp的时候就不用输入密码了。


分享到:


相關文章: