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
相关推荐
tmacfrank1 小时前
网络编程中的直接内存与零拷贝
java·linux·网络
瀚高PG实验室3 小时前
连接指定数据库时提示not currently accepting connections
运维·数据库
QQ2740287563 小时前
Soundness Gitpod 部署教程
linux·运维·服务器·前端·chrome·web3
淡忘_cx3 小时前
【frp XTCP 穿透配置教程
运维
qwfys2003 小时前
How to configure Linux mint desktop
linux·desktop·configure·mint
南方以南_3 小时前
Ubuntu操作合集
linux·运维·ubuntu
冼紫菜4 小时前
[特殊字符]CentOS 7.6 安装 JDK 11(适配国内服务器环境)
java·linux·服务器·后端·centos
Chuncheng's blog5 小时前
RedHat7 如何更换yum镜像源
linux
爱莉希雅&&&5 小时前
shell脚本之条件判断,循环控制,exit详解
linux·运维·服务器·ssh
wei_work@6 小时前
【linux】Web服务—搭建nginx+ssl的加密认证web服务器
linux·服务器·ssl