scp命令——基于SSH协议远程文件复制

scp命令是英文词组secure copy的缩写,其功能是基于SSH协议的远程文件复制。由于数据是经过SSH协议加密传输的,因此会比HTTP和FTP更加安全。

scp命令可以在多个Linux系统之间通过网络进行文件复制,而cp命令只能在一个Linux系统内部进行文件复制。

scp命令可以上传文件,也可以下载文件,语法格式分别介绍如下:

(1)上传文件的语法格式如下:

bash 复制代码
scp [选项] 本地文件名 远程服务器信息:远程文件名

(2)下载文件的语法格式如下:

bash 复制代码
scp [选项] 远程服务器信息:远程文件名 本地文件名

其中的远程服务器信息包括登录远程服务器的账号和服务器主机名或IP地址等,其形式与邮箱格式相同,如下所示,若未指定远程登录用户名,则默认使用当前客户端的登录用户名。

复制代码
zhangsan@192.168.18.188

或者

zhangsan@hostname001

常用选项如下:

|--------|---------------------|
| 选项 | 含义 |
| -l | 设置宽带限制 |
| -o | 设置ssh服务选项 |
| -P | 设置远程主机的端口号 |
| -p | 保留文件的修改时间、访问时间和权限属性 |
| -B | 使用批处理模式 |
| -q | 静默执行模式 |
| -c | 使用指定密钥对传输文件进行加密 |
| -r | 递归处理所有子文件 -C 使用压缩模式 |
| -S | 设置加密传输时所使用的程序 |
| -F | 设置ssh配置文件路径 |
| -v | 显示执行过程详细信息 |
| -i | 从指定文件中读取传输文件的密钥 |

1、将本地文件上传至服务器指定目录

(1)示例1,保持原文件名不变,服务器远程连接用户名为当前客户机登录用户名

bash 复制代码
# 将本地文件file1上传到服务器的/data目录下,文件名不变
[root@node1 ~]# scp /opt/file1 218.0.0.44:/data/

Authorized users only. All activities may be monitored and reported.
root@218.0.0.44's password: 
file1                                                  100%   79   399.7KB/s   00:00

(2)示例2,上传并更名,服务器远程连接用户名指定为zhangsan

bash 复制代码
# 将本地文件file2上传到服务器的/data目录下,并更名为f2
[root@node1 ~]# scp /opt/file2 zhangsan@218.0.0.44:/data/f2

Authorized users only. All activities may be monitored and reported.
zhangsan@218.0.0.44's password: 
file2                                                  100%   74   368.6KB/s   00:00  

2、将本地目录上传至服务器的指定目录

上传目录必须使用选项-r。

bash 复制代码
# 将本地目录/opt下的所有文件及子目录上传至服务器的/data目录
[root@node1 ~]# scp -r /opt/* 218.0.0.44:/data/

Authorized users only. All activities may be monitored and reported.
root@218.0.0.44's password: 
file1                                                  100%   79   494.9KB/s   00:00    
file2                                                  100%   74   662.0KB/s   00:00    
make_hotpatch                                          100%   20KB  76.7MB/s   00:00 

3、将服务器上的文件下载至本地目录

服务器远程连接用户名指定为zhangsan,下载/data/file1至本机的/download目录

bash 复制代码
# 将服务器上的文件/data/file1下载至本地的/download目录下,并保持原文件名
[root@node1 ~]# scp zhangsan@218.0.0.44:/data/file1 /download/

Authorized users only. All activities may be monitored and reported.
zhangsan@218.0.0.44's password: 
file1                                                  100%   79   437.6KB/s   00:00 

4、将服务器上的目录下载至本地目录

下载目录必须使用选项-r。

bash 复制代码
# 将服务器上的/data/目录下载至本地目录下
[root@node1 ~]# scp -r 218.0.0.44:/data/ /download/

Authorized users only. All activities may be monitored and reported.
root@218.0.0.44's password: 
make_hotpatch                                          100%   20KB  68.1MB/s   00:00    
file1                                                  100%   79     1.0MB/s   00:00    
file2                                                  100%   74   923.3KB/s   00:00
相关推荐
@大迁世界9 分钟前
紧急:React 19 和 Next.js 的 React 服务器组件存在关键漏洞
服务器·前端·javascript·react.js·前端框架
源之缘-OFD先行者9 分钟前
定制化 Live555 实战:按需开发低耗 RTSP 服务器,完美适配 C# 项目
运维·服务器·c#
Terry_Tsang10 分钟前
ceph mon 报错 full ratio(s) out of order 解决方法
服务器·前端·ceph
赖small强11 分钟前
【Linux 内存管理】Linux 低内存平台文件缓存导致的虚假内存不足问题分析与解决方案
linux·缓存·oom·水位线
古城小栈11 分钟前
Next.js高危漏洞致服务器沦为矿机
服务器·网络攻击模型
慾玄17 分钟前
ce复习--Chrony服务器
linux
wifi chicken23 分钟前
Linux Wlan无线网络开发之DHCP预留功能 实操demo
linux·运维·服务器
代码游侠26 分钟前
复习——线性表
linux·c语言·数据结构·学习·算法
DeeplyMind26 分钟前
第5章:并发与竞态条件-12:Locking Traps
linux·驱动开发·ldd
dragoooon3430 分钟前
[Linux网络基础——Lesson11.「NAT & 代理服务 & 内网穿透」]
linux·网络·智能路由器