大家好,欢迎来到IT知识分享网。
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

详细信息请参考help

参数解释:
-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!’

在192.168.102.110[远程机]普通用户odysee家目录中
1、创建一个scpRemote

测试:
方式1:
scp local_file remote_username@remote_ip:remote_folder
把22的local文件copy到110 scpRemote/下面
scp local odysee@192.168.102.110:/home/odysee/scpRemote
输入密码后执行成功

查看远程机是否存在

方式2:
scp local_file remote_ip:remote_folder/file
把22的local2文件copy到110 scpRemote/下面
scp local2 192.168.102.110:/home/odysee/scpRemote

查看远程机110

关于对目录的操作和文件类似
下面模拟一个:
1、 在本地机的scpLocal/创建一个scpLocal2文件
2、 在scpLocal2/创建一个local3文件并写入’hello scp3!’

测试:
我们把本地机的scpLocal copy到远程机的scpRemote/
注意-r递归copy
scp -r local_folder remote_username@remote_ip:remote_folder
即:
scp -r scpLocal odysee@192.168.102.110:/home/odysee/scpRemote
注意执行命令所在目录

查看远程机

成功
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 odysee@192.168.102.110:/home/odysee/scpRemote scpLocal

测试成功
注意:
如远程服务器防火墙为scp命令设置指定端口,我们需要使用-P来设置命令端口号
如下:
scp -P port[端口号] remote_username@remote_ip:remote_file local_folder
小提示:
远程复制文件或者目录还需要来回的输入用户或则密码,可能稍微有点麻烦。
下一篇配置ssh免密码登录,再使用scp的时候就不用输入密码了。
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/170443.html