如何使用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
相关推荐
斯普信专业组1 分钟前
Skywalking从部署集成到动态调优(下)
运维·skywalking·动态调优
liuy961539 分钟前
tcp服务器
服务器
Fcy64840 分钟前
初识Linux和Linux基础指令详细解析及shell的运行原理
linux·服务器·ubuntu·centos
王道长服务器 | 亚马逊云1 小时前
AWS Shield 与海外高防服务器的对比分析
服务器·云计算·aws
卓小帅的博客1 小时前
跨服务器快速传输数据
运维·服务器
朝阳5811 小时前
nuxt2 发布到线上
运维·服务器
芒果作者2 小时前
cursor注册无需手机号
运维·服务器·ai·cursor
拾光Ծ2 小时前
【Linux】入门指南:基础指令详解Part Two
linux·运维·服务器
闲人编程2 小时前
将你的Django/Flask应用部署到云服务器(Docker实战)
服务器·docker·容器·django·flask·部署·web