一、环境假设
-
电脑 A (IP: 192.168.1.100)
-
电脑 B (IP: 192.168.1.101)
-
两台电脑都安装了
rsync和openssh-server -
如果没有安装,使用以下命令:
yum install -y rsync openssh-server
yum install -y rsync
二、 操作
步骤一:在电脑 A 上生成 SSH 密钥
ssh-keygen -t ed25519 # 推荐,速度快。旧系统可用 -t rsa
按三次回车,使用默认路径和空密码。
-
生成的密钥对默认保存在
~/.ssh/id_ed25519(私钥) 和~/.ssh/id_ed25519.pub(公钥)。
步骤二:将 A 的公钥拷贝到 B
bash
# 在机器A上查看公钥
cat ~/.ssh/id_ed25519.pub
# 复制输出的内容,然后在机器B上执行:
echo "粘贴的公钥内容" >> ~/.ssh/authorized_keys
在电脑 A 上执行:
*
bash
ssh-copy-id username@192.168.1.101
输入 B 的登录密码,公钥会自动添加到 B 的 ~/.ssh/authorized_keys。
验证 :ssh username@192.168.1.101 应能无密码登录。
*
步骤三:实现双向免密(可选)
- 如果也需要从 B 无密码访问 A,在电脑 B 上重复步骤一和步骤二:
bash
# 在电脑 B 上操作
ssh-keygen -t ed25519
ssh-copy-id username@192.168.1.100
步骤四:使用 rsync 无需密码传输
从 A 推送文件到 B:
bash
# 将本地文件夹 /data 同步到 B 的 /backup 目录
rsync -avz -P /data/ username@192.168.1.101:/backup/
从 A 拉取 B 的文件:
bash
# 将 B 的 /data 文件夹拉取到本地的 /backup 目录
rsync -avz -P username@192.168.1.101:/data/ /backup/
三、高级进阶
- 1.自动化脚本
- 配合 cron 定时任务,实现自动同步:
bash
# 每天凌晨 2 点自动备份
0 2 * * * rsync -avz --delete /data/ nas:/backup/ >> /var/log/backup.log 2>&1