基于rsync,局域网内,无需密码互传

一、环境假设

  • 电脑 A (IP: 192.168.1.100)

  • 电脑 B (IP: 192.168.1.101)

  • 两台电脑都安装了 rsyncopenssh-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
相关推荐
一条懒鱼6662 小时前
Ansible之Playbook简单应用
网络·ansible
阿巴~阿巴~3 小时前
IPv4地址转换函数详解及C++容器安全删除操作指南
linux·服务器·c++·网络协议·算法·c++容器安全删除操作·ipv4地址转换函数
SKYDROID云卓小助手3 小时前
无人设备遥控器之差分信号抗干扰技术
网络·stm32·单片机·嵌入式硬件·算法
应茶茶3 小时前
VsCode通过SSH远程连接云服务器遇到主机密钥变更问题
服务器·vscode·ssh
skywalk81633 小时前
FreeBSD 14.3 轻量级Jail虚拟机:内存资源占用仅13MB的实战指南
运维·服务器·freebsd·jail
羑悻的小杀马特4 小时前
JuiceSSH+cpolar解锁手机远程Linux新姿势,无需公网IP,固定地址稳定用
linux·服务器·coplar
远程软件小帮手4 小时前
好用的远程软件!ToDesk、向日葵、UU远程横测
运维·服务器·游戏·电脑
顾安r4 小时前
11.14 脚本网页 青蛙过河
服务器·前端·python·游戏·html
YJlio4 小时前
ListDLLs & Handle 学习笔记(8.11):谁注入了 DLL?谁占着文件不放?一篇教你全搞定
网络·笔记·学习