Linux内网离线用rsync和inotify-tools实现文件夹文件单向同步和双向同步

lsyncd实现方式可参考https://www.jianshu.com/p/c075ccf89516

安装文件下载:相关文件下载

rsync默认都有,所以没有提供。

服务端和客户端均操作

服务端:双向同步其实都是服务端,只是单向同步时稍有区别

客户端:双向同步其实都是服务端

1、创建服务端和客户端密码文件

shell 复制代码
echo rsync_zyc_server:123456 > /etc/rsync_zyc_server.password
echo 123456 > /etc/rsync_zyc_client.password
# 修改密码访问权限,必须改
chmod 600 /etc/rsync_*

rsync_zyc_server.password:rsync服务配置里需要用到的认证文件和用户名

rsync_zyc_client.password:连接其他服务器的rsync服务时所需的密码文件

2、修改rsync配置文件并启动文件同步服务

vi /etc/rsyncd.conf

shell 复制代码
# /etc/rsyncd: configuration file for rsync daemon mode

# See rsyncd.conf man page for more options.

# configuration example:

# uid = nobody
# gid = nobody
# use chroot = yes
# max connections = 4
# pid file = /var/run/rsyncd.pid
# exclude = lost+found/
# transfer logging = yes
# timeout = 900
# ignore nonreadable = yes
# dont compress   = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2

# [ftp]
#        path = /home/ftp
#        comment = ftp export area

# 端口
port =10873
# 以 xxxx 用户启动进程
uid = root
gid = root

# 无需让rsync以root身份运行,允许接收文件的完整属性
fake super = yes

# 禁锢推送的数据至某个目录,不允许跳出该目录
# 允许chroot,提升安全性,客户端连接模块,首先chroot到模块path参数指定的目录下
# chroot为yes时必须使用root权限,且不能备份path路径外的链接文件
use chroot = no

# 最大连接数
max connections = 200

# 超时时间
timeout = 300

# pid文件路径
pid file = /var/run/rsyncd.pid

# 锁文件路径
lock file = /var/run/rsync.lock

# 剔除某些文件或目录不同步
exclude = lost+found/

# 记录传输文件日志
transfer logging = yes

# 指定日志文件
log file = /var/log/rsyncd_zyc.log

# 日志文件格式
log format = %t %a %m %f %b

# 忽略错误信息
ignore errors

# 对备份数据可读写
read only = false

# 不允许查看模块信息
list = false

# 定义虚拟用户,作为连接认证用户
auth users = rsync_zyc_server

# 定义rsync服务用户连接认证密码文件路径
secrets file = /etc/rsync_zyc_server.password

# 设置不需要压缩的文件
dont compress = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2

# 定义模块信息
[zycFileSync]
# 模块注释信息
comment = "双向同步目录测试"
# 定义备份数据目录,此处根据实际调整
path = /root/fileSyncRpm/testFiles/

[zycDatabaseSync]
comment = "数据库备份文件单向同步测试"
path = /root/fileSyncRpm/testDatabase/

3、安装inotify-tools

上传下载好的epel-release-7-11.noarch.rpm和inotify-tools-3.14-9.el7.x86_64.rpm

安装:rpm -iv *.rpm

服务端操作

双向同步的脚本:

shell 复制代码
vi /root/fileSyncRpm/inotify.sh
shell 复制代码
# 启动文件同步服务
rsync --daemon

# 远程主机ip地址
host=192.168.0.212

# 本地服务器同步目录(即同步该目录内的文件和子目录)
src=/root/fileSyncRpm/testFiles/

# 远程服务器 rsync 服务模块名
des=zycFileSync

# rsync服务用户连接认证密码文件路径
password=/etc/rsync_zyc_client.password

# 连接认证用户
user=rsync_zyc_server

# inotifywait 程序路径
inotifywait=/usr/bin/inotifywait

# 监听文件变化进行传输
$inotifywait -mrq -e 'modify,delete,create,attrib' $src |while read files;
do
    rsync -azP $src $user@$host::$des --port=10873 --password-file=${password};

    # 日志,可视情况开启
    # echo "${files} was rsynced!" >> ./rsync_inotify.log 2>&1;

done

单向同步的脚本:

shell 复制代码
vi /root/fileSyncRpm/databaseInotify.sh
shell 复制代码
# 启动文件同步服务
rsync --daemon

# 远程主机ip地址
host=192.168.0.212

# 本地服务器同步目录(即同步该目录内的文件和子目录)
src=/root/fileSyncRpm/testDatabase/

# 远程服务器 rsync 服务模块名
des=zycDatabaseSync

# rsync服务用户连接认证密码文件路径
password=/etc/rsync_zyc_client.password

# 连接认证用户
user=rsync_zyc_server

# inotifywait 程序路径
inotifywait=/usr/bin/inotifywait

# 监听文件变化进行传输
$inotifywait -mrq -e 'modify,delete,create,attrib' $src |while read files;
do
    rsync -azP $src $user@$host::$des --port=10873 --password-file=${password};

    # 日志,可视情况开启
    # echo "${files} was rsynced!" >> ./rsync_inotify.log 2>&1;

done

启动单向同步和双向同步脚本(手动)

shell 复制代码
nohup sh inotify.sh > inotify.log 2>&1 &
nohup sh databaseInotify.sh > databaseInotify.log 2>&1 &

客户端操作

双向同步的脚本:

shell 复制代码
vi /root/fileSyncRpm/inotify.sh
shell 复制代码
# 启动文件同步服务
rsync --daemon

# 远程主机ip地址
host=192.168.0.211

# 本地服务器同步目录(即同步该目录内的文件和子目录)
src=/root/fileSyncRpm/testFiles/

# 远程服务器 rsync 服务模块名
des=zycFileSync

# rsync服务用户连接认证密码文件路径
password=/etc/rsync_zyc_client.password

# 连接认证用户
user=rsync_zyc_server

# inotifywait 程序路径
inotifywait=/usr/bin/inotifywait

# 监听文件变化进行传输
$inotifywait -mrq -e 'modify,delete,create,attrib' $src |while read files;
do
    rsync -azP $src $user@$host::$des --port=10873 --password-file=${password};

    # 日志,可视情况开启
    # echo "${files} was rsynced!" >> ./rsync_inotify.log 2>&1;

done

启动双向同步脚本(手动)

shell 复制代码
nohup sh inotify.sh > inotify.log 2>&1 &

测试

在服务端和客户端创建文件测试

shell 复制代码
cd /root/fileSyncRpm/testFiles
touch b.1

设置开机自启动

创建服务单元文件:在 /etc/systemd/system 目录下创建一个新的服务单元文件,例如 zycFileInotify.service。 打开终端并运行:

shell 复制代码
vi /etc/systemd/system/zycFileInotify.service
shell 复制代码
[Unit]
Description=Inotify File Sync Script
After=network.target

[Service]
Type=simple
ExecStart=/bin/bash /root/fileSyncRpm/inotify.sh
Restart=on-failure

[Install]
WantedBy=multi-user.target

这里 ExecStart 行指定了要执行的脚本位置。

加载并启用服务:保存并关闭文件后,运行以下命令来加载服务并设置开机启动:

shell 复制代码
sudo systemctl daemon-reload
sudo systemctl enable zycFileInotify.service
sudo systemctl start zycFileInotify.service
sudo systemctl status zycFileInotify.service
相关推荐
si莉亚4 分钟前
2026.3.31成功安装Ubuntu22.04+ROS2记录
linux·c++·开源
上海云盾安全满满5 分钟前
服务器很卡,是CC攻击造成的吗
运维·服务器·网络
RrEeSsEeTt7 分钟前
【HackTheBox】- Monteverde 靶机学习
linux·网络安全·渗透测试·kali·红队·hackthebox·ad域
信创DevOps先锋7 分钟前
Gitee:中国DevOps生态的破局者与赋能者Gitee:中国DevOps生态的破局者与赋能者
运维·gitee·devops
污斑兔15 分钟前
Debian 普通用户无 sudo 权限问题排查与解决
运维·debian
美式请加冰31 分钟前
Linux权限的概念
linux·运维·服务器
zandy101131 分钟前
指标管理的AI自治之路:衡石平台如何实现异常检测、血缘分析与智能推荐的自动化治理
运维·人工智能·自动化
两年半的个人练习生^_^36 分钟前
List集合的使用和源码
linux·windows·list
CSND7401 小时前
什么是Docker,容器是什么,镜像是什么,一文解读
运维·人工智能·docker·容器
同聘云1 小时前
阿里云国际站云服务器价格持续走低会取代VPS主机吗?
服务器·阿里云·腾讯云