步骤 1: 确保scp命令可用
首先,确保你的服务器上安装了scp。在大多数Linux发行版中,scp是随SSH一起安装的,但你可以通过运行以下命令来检查:
scp --version
如果命令返回版本信息,则scp已安装;否则,你可能需要安装openssh-clients包(在RHEL/CentOS/Fedora上)或openssh-client(在Debian/Ubuntu上)。
步骤 2: 准备SSH密钥对
如果两台服务器之间还没有设置无密码SSH登录,你需要生成SSH密钥对并在目标服务器上设置公钥。这可以通过以下命令在本服务器上完成:
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的文件,你可以使用以下命令:
scp example.txt user@target-server-ip:/path/to/target/directory
这里的/path/to/target/directory是目标服务器上的目录路径。
步骤 4: 使用scp上传文件夹
如果你想上传一个目录及其所有内容,需要使用-r选项来递归复制:
scp -r source-directory user@target-server-ip:/path/to/target/directory
这里的source-directory是你想上传的目录的完整路径,/path/to/target/directory是目标服务器上的目标目录。
步骤 5: 检查文件和文件夹是否成功上传
在目标服务器上,你可以使用ls命令来检查文件或文件夹是否已成功上传:
ssh user@target-server-ip ls /path/to/target/directory
步骤 6: 验证文件完整性
为了确保文件在传输过程中没有损坏,你可以比较源文件和目标文件的MD5或SHA256哈希值:
md5sum source-file
ssh user@target-server-ip md5sum /path/to/target/directory/source-file
或者使用SHA256:
sha256sum source-file
ssh user@target-server-ip sha256sum /path/to/target/directory/source-file