rsync 具有安全性高、备份迅速、支持增量备份等优点,通过 rsync 可以解决对实时性要求不是很高的数据备份需求。如果实时性高的情况下,就会体现出他的不足,虽然可以利用任务计划来触发同步,但还是有一定的时间差,并且 rsync 在同步数据的时候,要遍历整个目录树后进行比对,文件数量达到一定量级的情况下,这是很低效的做法。所以就有了今天的 rsync + inofity 。

inotify 是一种强大的、细粒度的、异步文件系统时间监控机制,Linux 内核从 2.6.13 起,加入了对inotify 的支持,他可以监控文件系统中 添加、删除、修改、移动等各种细微事件,第三方软件inotify-tools 利用这个内核接口就能监控文件系统下文件的各种变化,从而触发 rsync 同步数据,解决了数据同步实时性问题。

一、    在 web(web安装rsync就行不需要配置rsyncd.conf) 、web_bak 安装 rsync(web在/var/www/html/下更新信息,在wen_bak的/var/www/html/下跟着更新所有数据)

IP:192.168.1.80是源服务器就是服务端(yum安装rsync就行,不需要配置),192.168.1.81是目的服务器就是客户端(yum安装rsync,还要配置/etc/rsyncd.conf)。

[root@localhost ~]# yum -y install rsync

二、配置 web_bak rsync

[root@web_bak]# vim /etc/rsyncd.conf   ## 配置文件需手工创建
# rsync
uid = nobody
gid = nobody
use chroot = no
max connections = 10
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsyncd.lock
log file = /var/run/rsyncd.log
[web1]
path = /var/www/html/(
客户端的路径不一样要和服务端一样,自己定)
comment = web_bak file
ignore errors
read only = no
write only = no
hosts allow = 192.168.1.80  
#web 的 IP
hosts deny = *
list = false
uid = root
gid = root
auth users = rsync80
secrets file = /etc/rsync.pass

[root@web_bak]#
echo"rsync80:123456" > /etc/rsync.pass
[root@web_bak]#
chown root.root/etc/rsync.pass
[root@web_bak]#
chmod 600/etc/rsync.pass

三、以守护进程启动 rsync ,并加入开机启动

[root@web_bak]# rsync --daemon
[root@web_bak]#
ps aux | greprsync
root      1344 0.1  0.0 107612   660 ?        Ss  19:17   0:00 rsync --daemon
root      1347  1.0  0.1 103240   864 pts/0    S+   19:17  0:00 grep rsync

[root@web_bak]#
which rsync
/usr/bin/rsync
[root@web_bak]# echo"/usr/bin/rsync --daemon" >> /etc/rc.d/rc.local
[root@web_bak]# iptables -I INPUT -p tcp--dport 873 -j ACCEPT
[root@web_bak]# service iptables save
[root@web_bak]# service iptables restart

(蓝色这里是防火墙根据自己需求,我关闭防火墙了,所以这部我不操作)

四、在 web 上安装 inotify-tools

[root@localhost]# uname -r
2.6.32-358.el6.x86_64
[root@localhost]#
ll/proc/sys/fs/inotify/
总用量 0
-rw-r--r-- 1 root root 0 5月  20 19:29max_queued_events
-rw-r--r-- 1 root root 0 5月  20 19:29 max_user_instances
-rw-r--r-- 1 root root 0 5月  20 19:29max_user_watches

[root@localhost]#
yum -y installgcc gcc-c++ make
[root@localhost src]#
tar zxf inotify-tools-3.14.tar.gz
[root@localhost src]#
cdinotify-tools-3.14
[root@localhost inotify-tools-3.14]#
./configure ; make ; make install
[root@localhost ~]#
ll/usr/local/bin/inotifywa*
-rwxr-xr-x. 1 root root 44279 5月  21 22:57/usr/local/bin/inotifywait
-rwxr-xr-x. 1 root root 41369 5月  21 22:57/usr/local/bin/inotifywatch

# inotifywait
用于等待文件或文件集的一个特定时间,他可以监控任何文件及目录的设置,并且可以递归监控整个目录树。
# inotifywatch 用于收集被监控的文件系统统计数据,包括每个 inotify 时间发生的次数等信息。
inotify 接口参数介绍 (用来限制 inotify 消耗kernel memory 的大小,由于是内存参数,可以随时调节大小。)
/proc/sys/fs/inotify/max_queued_evets 
# 表示调用 inotify_init 时分配给inotify instance 中可排队的 event 的数目的最大值,超出这个值的事件被丢弃,但会触发 IN_Q_OVERFLOW 事件。
/proc/sys/fs/inotify/max_user_instances
# 表示每个 real user ID 可创建的inotify instatnces 的数量上限。
/proc/sys/fs/inotify/max_user_watches
# 表示每个 inotify instatnces 可监控的最大目录数量。如果监控文件数据巨大,可以增加此值,如 echo 20000000 > 上述文件
inotifywait 参数介绍 (inotifywait 是一个监控等待事件,可以配合 shell 脚本使用。)
-m   即 --monitor 表示始终保持事件监听状态
-r   即 --recursive 表示递归查询目录
-q   即 --quiet 表示打印监控事件
-e   即 --event 通过此参数可以指定要监控的事件,如:modify、delete、create、attrib 等。

五、配置 web 内容发部节点

[root@localhost ~]# vim /usr/bin/inotify_rsync.sh   ## 自己创建
#!/bin/bash
IP1=192.168.1.81        # web_bak
的 IP
src=/var/www/html/(服务端这个路径不一样要和客户端一样,自己定)    # 需要同步的本地路径
dst1=web1                   #web_bak 上设置的验证模块名
user1=rsync80            # 同步用户
/usr/local/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f%e'-e modify,delete,create,attrib $src | while read files
                    do
                   /usr/bin/rsync -vzrtopg --delete --progress --password-file=/etc/rsync.pass$src $user1@$IP1::$dst1 > /dev/null
                    echo"${files} was rsynced" >> /tmp/rsync.log 2>&1
                    done
# --timefmt:指定时间的输出格式。
  --format: 指定变化文件的详细信息。
这两个参数一般配合使用,通过指定输出格式,输出类似与:
22/05/14 01:25 /var/www/html/.abc.123.swpDELETE was rsynced

脚本授权:chmod  -R  755 /usr/bin/inotify_rsync.sh

[root@localhost ~]# echo "123456" >/etc/rsync.pass  # 注意这里的密码文件中只有用户密码没有用户,格式跟 web_bak 的不同
[root@localhost ~]#
chownroot.root /etc/rsync.pass
[root@localhost ~]#
chmod 600/etc/rsync.pass
[root@localhost ~]#
/usr/bin/inotify_rsync.sh&
[root@localhost ~]# echo "/usr/bin/inotify_rsync.sh&" >> /etc/rc.d/rc.local

然后在 web /var/www/html/ 下执行操作,看看 web_bak 会不会同步数据