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
相关推荐
❀͜͡傀儡师13 小时前
Docker一键部署Nexus Terminal,高颜值SSH新体验
docker·容器·ssh
Protein_zmm13 小时前
第一章 计算机网络和因特网(下)
服务器·计算机网络·php
dyxal13 小时前
非对称加密:彻底解决密钥分发难题的数字安全革命
服务器·网络·安全
写代码的学渣14 小时前
Ubuntu/麒麟默认锁定root账户
linux·运维·ubuntu
wdfk_prog15 小时前
[Linux]学习笔记系列 -- [block]bfq-iosched
linux·笔记·学习
q***99415 小时前
IPV6公网暴露下的OPENWRT防火墙安全设置(只允许访问局域网中指定服务器指定端口其余拒绝)
服务器·安全·php
LCG元15 小时前
Linux 文本处理三剑客(grep, sed, awk)核心用法与实战
linux
RisunJan15 小时前
Linux命令-exportfs命令(管理NFS服务器上共享文件系统)
linux·运维·服务器
动感小麦兜15 小时前
服务器搭建
linux·服务器·python
LSL666_16 小时前
云服务器安装Tomcat
运维·服务器·tomcat