网站首页 > 文章精选 正文
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的时候就不用输入密码了。
猜你喜欢
- 2025-03-26 一文读懂PLC过程映像区和外设地址,PLC编程真的超简单
- 2025-03-26 西门子1200/1500PLC使用PEEK和POKE指令实现数据块间接寻址
- 2025-03-26 西门子S7-1200/1500的寻址方式及其使用
- 2025-03-26 微机原理篇——8086CPU的内部结构
- 2025-03-26 关于芯片,这里有你没看过的硬核科普
- 2025-03-26 针对苹果M和A系列CPU的新型侧信道攻击
- 2025-03-26 2018年下半年网络工程师上午试题(2018年上半年网络工程师上午真题及答案)
- 2025-03-26 FANUC发那科法兰克数控车床程序原点,坐标原点,坐标系详解
- 2025-03-26 轻松理解西门子PLC间接寻址和指针
- 2025-03-26 日常计算机,不日常的校验码:硬件知识大起底
- 最近发表
- 标签列表
-
- newcoder (56)
- 字符串的长度是指 (45)
- drawcontours()参数说明 (60)
- unsignedshortint (59)
- postman并发请求 (47)
- python列表删除 (50)
- 左程云什么水平 (56)
- 计算机网络的拓扑结构是指() (45)
- 稳压管的稳压区是工作在什么区 (45)
- 编程题 (64)
- postgresql默认端口 (66)
- 数据库的概念模型独立于 (48)
- 产生系统死锁的原因可能是由于 (51)
- 数据库中只存放视图的 (62)
- 在vi中退出不保存的命令是 (53)
- 哪个命令可以将普通用户转换成超级用户 (49)
- noscript标签的作用 (48)
- 联合利华网申 (49)
- swagger和postman (46)
- 结构化程序设计主要强调 (53)
- 172.1 (57)
- apipostwebsocket (47)
- 唯品会后台 (61)
- 简历助手 (56)
- offshow (61)