Rsync + Sersync 实时数据同步方案

方案架构

  • 源服务器:部署 Sersync(监控文件变化) + Rsync(推送数据)
  • 目标服务器:部署 Rsync Daemon(接收数据)
  • 同步逻辑:源服务器文件变动 → Sersync 实时触发 → Rsync 增量同步至目标服务器

详细实施步骤

一、目标服务器配置(数据接收端)

  1. 安装 Rsync

bash

yum install rsync -y # CentOS

apt install rsync -y # Ubuntu

  1. 创建 Rsync 配置文件

bash

vim /etc/rsyncd.conf

ini

uid = root

gid = root

use chroot = no

max connections = 2000

pid file = /var/run/rsyncd.pid

lock file = /var/run/rsync.lock

log file = /var/log/rsyncd.log

data_backup # 模块名称(客户端同步时指定)

path = /data/backup # 同步目录

comment = Backup Directory

read only = no # 允许写入

auth users = rsync_user # 认证用户

secrets file = /etc/rsync.password # 密码文件

  1. 创建认证文件

bash

echo "rsync_user:your_password" > /etc/rsync.password

chmod 600 /etc/rsync.password

  1. 创建同步目录

bash

mkdir -p /data/backup

chown -R rsync_user:rsync_user /data/backup

  1. 启动 Rsync 守护进程

bash

systemctl start rsyncd

systemctl enable rsyncd

  1. 开放防火墙端口

bash

firewall-cmd --add-port=873/tcp --permanent

firewall-cmd --reload


二、源服务器配置(数据发送端)

  1. 安装 Rsync

bash

yum install rsync -y # CentOS

apt install rsync -y # Ubuntu

  1. 创建 Rsync 密码文件

bash

echo "your_password" > /etc/rsync.password

chmod 600 /etc/rsync.password

  1. 测试手动同步

bash

rsync -avz /source/data/ rsync_user@目标服务器IP::data_backup --password-file=/etc/rsync.password

  • 作用:验证配置正确性,确保网络和权限正常。
  1. 安装 Sersync

bash

wget https://github.com/wsgzao/sersync/raw/master/sersync2.5.4_64bit_binary_stable_final.tar.gz

tar -zxvf sersync2.5.4_64bit_binary_stable_final.tar.gz -C /opt/

mv /opt/GNU-Linux-x86/ /opt/sersync

  1. 修改 Sersync 配置文件

bash

vim /opt/sersync/confxml.xml

xml

<!-- 监控目录设置 -->

<localpath watch="/source/data"> <!-- 源服务器需同步的目录 -->

<remote ip="目标服务器IP" name="data_backup"/> <!-- 目标服务器模块名 -->

</localpath>

<!-- Rsync 参数 -->

<rsync>

<commonParams params="-artuz"/> # 归档模式(保留属性)

<auth start="true" users="rsync_user" passwordfile="/etc/rsync.password"/>

<timeout start="false" time="100"/> <!-- 超时设置 -->

</rsync>

  1. 启动 Sersync

bash

/opt/sersync/sersync2 -d -r -o /opt/sersync/confxml.xml

  • 参数说明
    • -d:守护进程模式
    • -r:启动时先全量同步
    • -o:指定配置文件
  1. 设置开机自启

bash

echo "/opt/sersync/sersync2 -d -r -o /opt/sersync/confxml.xml" >> /etc/rc.local

chmod +x /etc/rc.local


三、验证实时同步

  1. 在源服务器创建测试文件

bash

touch /source/data/testfile.txt

  1. 检查目标服务器同步结果

bash

ls /data/backup # 应出现 testfile.txt

  1. 查看 Sersync 日志

bash

tail -f /opt/sersync/rsync_fail_log.sh # 同步失败日志


四、多维优化与监控

1. 性能优化

  • 调整 inotify 限制(解决监控文件数不足问题):

bash

echo "fs.inotify.max_user_watches=1000000" >> /etc/sysctl.conf

sysctl -p

  • Rsync 带宽限制(避免影响业务):

xml

<!-- 在 confxml.xml 中增加 -->

<commonParams params="--bwlimit=10240 -artuz"/> <!-- 限速 10MB/s -->

2. 高可用方案

  • 双活监控:部署多个 Sersync 进程监控不同目录。
  • 异常重启:添加 crontab 监控进程:

bash

*/5 * * * * pgrep sersync2 || /opt/sersync/sersync2 -d -o /opt/sersync/confxml.xml

3. 安全加固

  • Rsync 最小权限
    • 目标服务器使用非 root 用户运行 Rsync。
    • 配置文件设置 uid = rsync_user , gid = rsync_user
  • SSH 隧道加密

xml

<!-- 修改 confxml.xml -->

<rsync>

<ssh start="true" port="22" user="rsync_user"/>

</rsync>

4. 故障排查工具

  • 手动触发同步

bash

/opt/sersync/sersync2 -r -o /opt/sersync/confxml.xml

  • 查看 inotify 事件

bash

tail -f /proc/sys/fs/inotify/* # 监控事件队列


方案优势

  1. 秒级延迟:Sersync 基于 inotify 内核事件触发,响应速度 <1s。
  2. 增量高效:Rsync 只同步变化部分,节省带宽。
  3. 低资源占用:Sersync 单进程设计,CPU/内存消耗极低。
  4. 断点续传:Rsync 支持传输中断后续传。

注意 :大规模集群建议使用 LsyncdDRBD,单服务器场景本方案为最优解。

相关推荐
ScilogyHunter5 分钟前
GCC完全指南
linux·gcc
CodeStats14 分钟前
从 CPU 指令到 JVM 进程:彻底讲透 Java 执行 main 方法时,类加载、主线程、栈帧入栈的完整底层逻辑
java·linux·开发语言
努力努力再努力wz2 小时前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表
Jurio.3 小时前
开源 Codex Sticky:在终端 Codex CLI 长对话中始终固定底部输入框
linux·rust·github·开源软件·codex·codex cli
无足鸟ICT3 小时前
【RHCA+】撤销和恢复撤销快捷键
linux
质造者3 小时前
LangChain + Ollama + Tavily 实现旅游问答系统
linux·人工智能·python·langchain·rag
持梦远方3 小时前
MSF 木马制作 + 永恒之蓝漏洞上传执行木马 实战教程
网络安全
starvapour3 小时前
Ubuntu部署gitlab频繁出现502的问题
linux·ubuntu·gitlab
zhangfeng11334 小时前
ps aux讲解,结合国家超算中心 hpc apptainer
linux·服务器·网络