如何使用scp命令上传本服务器的文件及文件夹到另外一台服务器

步骤 1: 确保scp命令可用

首先,确保你的服务器上安装了scp。在大多数Linux发行版中,scp是随SSH一起安装的,但你可以通过运行以下命令来检查:

scp --version

如果命令返回版本信息,则scp已安装;否则,你可能需要安装openssh-clients包(在RHEL/CentOS/Fedora上)或openssh-client(在Debian/Ubuntu上)。
步骤 2: 准备SSH密钥对

如果两台服务器之间还没有设置无密码SSH登录,你需要生成SSH密钥对并在目标服务器上设置公钥。这可以通过以下命令在本服务器上完成:

bash 复制代码
ssh-keygen -t rsa -b 4096 -C "your_email@example.com"

然后,将生成的公钥发送到目标服务器:

ssh-copy-id user@target-server-ip

这里的user应该是目标服务器上的用户名,target-server-ip是目标服务器的IP地址。
步骤 3: 使用scp上传文件

一旦SSH配置完成,你可以使用scp上传文件。例如,如果你想上传一个名为example.txt的文件,你可以使用以下命令:

bash 复制代码
scp example.txt user@target-server-ip:/path/to/target/directory

这里的/path/to/target/directory是目标服务器上的目录路径。
步骤 4: 使用scp上传文件夹

如果你想上传一个目录及其所有内容,需要使用-r选项来递归复制:

bash 复制代码
scp -r source-directory user@target-server-ip:/path/to/target/directory

这里的source-directory是你想上传的目录的完整路径,/path/to/target/directory是目标服务器上的目标目录。

步骤 5: 检查文件和文件夹是否成功上传

在目标服务器上,你可以使用ls命令来检查文件或文件夹是否已成功上传:

bash 复制代码
ssh user@target-server-ip ls /path/to/target/directory

步骤 6: 验证文件完整性

为了确保文件在传输过程中没有损坏,你可以比较源文件和目标文件的MD5或SHA256哈希值:

md5sum source-file

bash 复制代码
ssh user@target-server-ip md5sum /path/to/target/directory/source-file

或者使用SHA256:

sha256sum source-file

bash 复制代码
ssh user@target-server-ip sha256sum /path/to/target/directory/source-file
相关推荐
少妇的美梦12 小时前
logstash教程
运维
chen94513 小时前
k8s集群部署vector日志采集器
运维
chen94513 小时前
aws ec2部署harbor,使用s3存储
运维
christine-rr18 小时前
linux常用命令(4)——压缩命令
linux·服务器·redis
東雪蓮☆18 小时前
深入理解 LVS-DR 模式与 Keepalived 高可用集群
linux·运维·服务器·lvs
qq_2642208918 小时前
LVS负载均衡群集和LVS+Keepalived群集
运维·负载均衡·lvs
乌萨奇也要立志学C++18 小时前
【Linux】进程概念(二):进程查看与 fork 初探
linux·运维·服务器
雨落Liy18 小时前
Nginx 从入门到进阶:反向代理、负载均衡与高性能实战指南
运维·nginx·负载均衡
Yyyy48219 小时前
Nginx负载均衡集群实验步骤
运维·nginx·负载均衡
绿箭柠檬茶19 小时前
Ubuntu 服务器配置转发网络访问
服务器·网络·ubuntu