1. 简介 搞服务器运维的,手里没几件趁手的工具可不行。今天咱们就来聊聊数据同步和监控领域的两个“老伙计”:rsync 和 Inotify。 rsync是个什么角色? 简单说,它是Linux系统下一款非常高效的数据镜像备份工具。速度快是它最大的特点,尤其擅长增量备份。不管你是想本地复制,还是想通过S
搞服务器运维的,手里没几件趁手的工具可不行。今天咱们就来聊聊数据同步和监控领域的两个“老伙计”:rsync 和 Inotify。
rsync是个什么角色?
长期稳定更新的攒劲资源: >>>点此立即查看<<<
简单说,它是Linux系统下一款非常高效的数据镜像备份工具。速度快是它最大的特点,尤其擅长增量备份。不管你是想本地复制,还是想通过SSH、甚至专门的rsync服务进行远程同步,它都能轻松胜任。
那Inotify又起什么作用?
如果说rsync负责“搬东西”,那Inotify就是负责“盯梢”的。它是一种强大且异步的文件系统事件监控机制。文件目录里任何的风吹草动——比如创建、删除、修改、移动——都逃不过它的“眼睛”。基于这个内核接口,我们就能实时掌握文件系统的每一个细微变化。
把它们俩结合起来用,会擦出怎样的火花?下面这个实验,就是打造一套“实时感知、自动同步”的备份系统。
| IP地址 | 扮演角色 |
|---|---|
| 192.168.153.180 | 备份源 (Sync Client + Inotify监控端) |
| 192.168.153.181 | 备份端 (Rsync Server) |
为了让实验过程畅通无阻,有个准备工作必须先做:把两台机器的防火墙和SELinux都关掉。当然,生产环境可不能这么干,得根据安全策略配置好放行规则。
关闭防火墙:
systemctl stop firewalld
关闭SELinux:
setenforce 0
好,环境准备好了,咱们先从备份端,也就是接收文件的那台机器开始配置。
3.1 安装rsync工具
第一步很简单,直接通过yum安装:
yum -y install rsync
3.2 修改rsync配置文件
安装完成后,关键步骤是配置它的服务端。编辑配置文件:
vim /etc/rsyncd.conf
把内容修改成下面这样(注意:使用前务必删掉所有注释,否则可能因格式问题导致服务启动失败):
uid=root gid=root use chroot = no max connections = 10 strict modes = yes pid file = /var/run/rsyncd.pid lock file = /var/run/rsyncd.lock log file = /var/log/rsyncd.log [rsync] path = /opt # 这是备份文件存放的路径 comment = rsync ignore errors # 跳过错误 read only = no # 允许读 write only = no # 允许写 hosts allow = 192.168.153.180 # 只允许备份源IP连接 list = false auth users = rsync_user # 认证用户名
3.3 创建密码文件并修改权限
光有用户名不够,还得配上密码。创建一个密码文件:
echo "rsync_user:123" > /etc/rsync.password
出于安全考虑,这个文件的权限必须收紧:
chmod 600 /etc/rsync.password
3.4 启动rsync并查看端口验证
配置妥当,现在可以启动rsync守护进程了:
rsync --daemon
怎么确认服务真的跑起来了?检查一下它默认监听的873端口状态就知道了:
netstat -ntlp|grep 873 tcp 0 0 0.0.0.0:873 0.0.0.0:* LISTEN 1583/rsync tcp6 0 0 :::873 :::* LISTEN 1583/rsync
看到这两行监听信息,说明备份端的服务已经就绪,在等着客户端来连接了。
备份端配置好了,接下来轮到“源头”这边。这里的任务更核心:不仅要能推送数据,还要装上“眼睛”来监控变化。
4.1 安装epel源和所需工具
我们需要安装inotify-tools,而它通常在EPEL源里。所以先装上EPEL源:
yum -y install epel-release
然后一次性把需要的工具都装上:
yum -y install inotify-tools rsync
4.2 配置rsync同步密码
源端作为客户端,不需要完整的服务端配置,但需要知道访问备份端的密码。注意,这里只写密码,不用用户名:
echo "123" > /etc/rsync.password
同样,权限必须设置为600:
chmod 600 /etc/rsync.password
4.3 编写inotify监控脚本
重头戏来了!我们将编写一个脚本,让inotifywait实时监控目录,一旦有变化,就立刻触发rsync同步。这才是实现“实时”的关键。
vim inotify.sh
#!/bin/bash
ip=192.168.153.181 #备份端IP
src=/opt/rsync_src #需要监控和同步的源目录
dst=rsync #对应备份端的模块名
user=rsync_user # 认证用户名
/usr/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f' -e modify,delete,create,attrib ${src} | while read file
do
rsync -vzrtopg --delete --progress $src $user@$ip::$dst --password-file=/etc/rsync.password > /dev/null && echo "$src was rsyncd"
done
3.4 创建被监控的源目录
脚本里指定的源目录,我们现在创建它:
mkdir /opt/rsync_src
3.5 执行脚本,开始监控
现在,让我们的监控脚本跑起来:
sh inotify.sh
脚本会停留在后台持续监控。是骡子是马,该拉出来遛遛了。
3.6 测试文件创建同步
新开一个终端窗口,进入被监控的目录,创建两个测试文件:
cd /opt/rsync_src echo 111 > 1.txt echo 222 > 2.txt
3.7 在备份端验证
立刻切换到备份端(181主机),检查目标目录。怎么样?两个新文件应该已经静静地躺在那里了:
ls /opt/rsync_src/ 1.txt 2.txt
3.8 测试文件删除同步
实时同步,当然也得包括删除操作。回到源端,删掉其中一个文件:
cd /opt/rsync_src rm -f 1.txt
再次查看备份端,你会发现,不仅仅是新增,连删除操作也被完美同步过去了:
ls /opt/rsync_src/ 2.txt
至此,一个基于Inotify和Rsync的简易实时同步系统就搭建并验证完成了。你可以看到,从文件创建到删除,所有操作都近乎实时地反应在了备份端。这,就是组合工具的威力。
侠游戏发布此文仅为了传递信息,不代表侠游戏网站认同其观点或证实其描述