关于rsync的配置请参考博文:http://www.cnblogs.com/snsdzjlz320/p/5630695.html

实验环境

(1) Rsync服务器:10.0.10.158

(2) Rsync客户端:10.0.10.173


Inotify都在客户端配置

1.查看系统是否支持inotify

# ls /proc/sys/fs/inotify/
max_queued_events max_user_instances max_user_watches  #这些值一般不去修改但在监控的文件数量较大时要根据需求调整 # cat /proc/sys/fs/inotify/max_queued_events #设置inotify实例事件(event)队列可容纳的事件数量
16384 # cat /proc/sys/fs/inotify/max_user_instances #设置每个用户可以运行的inotifywait或inotifywatch命令的进程数
128 # cat /proc/sys/fs/inotify/max_user_watches #设置inotifywait或inotifywatch命令可以监视的文件数量(单进程)
8192

2.安装inotify

# tar xvf inotify-tools-3.14.tar.gz
# cd inotify-tools-3.14
# ./configure --prefix=/usr/local/inotify
# make –j 2
# make install

3.设置系统环境变量

# vim /etc/profile     
PATH=“$PATH:/usr/local/inotify/bin”   #在文件中添加这行
# source /etc/profile # vim /etc/ld.so.conf
/usr/local/inotify/lib  #在文件中添加这行
# ldconfig

inotify工具与使用

# ls /usr/local/inotify/bin/
inotifywait inotifywatch

inotifywait
      inotifywait用于等待文件或文件集上的一个特定事件,它可以监控任何文件和目录设置,并且可以递归地监控整个目录树。

inotifywatch
      用于收集被监控的文件系统统计数据,包括每个inotify事件发生多少次等信息。

inotifywait常用选项
       -m,--monitor       表示始终保持事件监听状态

-r  ,--recursive     表示递归查询目录

-q ,--quiet           表示打印出监控事件

-e ,--event          通过此参数可以指定要监控的事件

Inotifywait支持的事件类型

access                文件读取

modify                文件更改

attrib                   文件属性更改,如权限,时间戳等

close_write         以可写模式打开的文件被关闭,不代表此文件一定已经写入数据

close_nowrite     以只读模式打开的文件被关闭

close                   文件被关闭,不管它是如何打开的

open                   文件打开

moved_to          一个文件或目录移动到监听的目录,即使是在同一目录内移动,此事件也触发

moved_from     一个文件或目录移出监听的目录,即使是在同一目录内移动,此事件也触发

move                 包括moved_to和 moved_from

move_self         文件或目录被移除,之后不再监听此文件或目录

create               文件或目录创建

delete               文件或目录删除

delete_self        文件或目录移除,之后不再监听此文件或目录

unmount           文件系统取消挂载,之后不再监听此文件系统

--timefmt
       %Y      表示年份

%m     表示月份

%d      表示天数

%H      表示小时

%M      表示分钟

--format
       %w    表示发生事件的目录

%f      表示发生事件的文件

%e     表示发生的事件

%Xe   事件以“X”分隔

%T      使用由–timefmt定义的时间格式


Rsync+Inotify连续监控脚本

# vim /usr/local/inotify/bin/webroot-bk.sh

#!/bin/bash
webserver=10.0.10.158
src="/var/www/html/"
dst1="webroot"
username=admin
/usr/local/inotify/bin/inotifywait -mrq --timefmt '%y-%m-%d %H:%M' \
--format '%T%w%f%e' -e close_write,delete,create,attrib ${src} \
| while read files
do
rsync -vzrtopg --delete --progress --password-file=/etc/rsync/password $src $username@$webserver::$dst1 &>/dev/null && echo "${files} was rsynced" &>> /var/log/rsyncd.log || echo "Error: ${files} not rsynced" &>> /var/log/rsyncd.log
done

运行与验证

# ./webroot-bk.sh &    #脚本放在后台运行
[1] 6559
# cd /var/www/html/
# ls
haha index.html new.html page_2.html page.html # touch inotify_new.html #客户端上新建文件
# cat /var/log/rsyncd.log #查看日志
16-06-30 16:11/var/www/html/inotify_new.htmlCREATE was rsynced
16-06-30 16:11/var/www/html/inotify_new.htmlATTRIB was rsynced
16-06-30 16:11/var/www/html/inotify_new.htmlCLOSE_WRITE,CLOSE was rsynced # mkdir /var/www/html/test_inotify #客户端上新建目录
# cat /var/log/rsyncd.log
16-06-30 16:11/var/www/html/inotify_new.htmlCREATE was rsynced
16-06-30 16:11/var/www/html/inotify_new.htmlATTRIB was rsynced
16-06-30 16:11/var/www/html/inotify_new.htmlCLOSE_WRITE,CLOSE was rsynced
16-06-30 16:21/var/www/html/test_inotifyCREATE,ISDIR was rsynced
# ls /var/www/html/  #回到服务器上看是不是已经同步了
haha index.html inotify_new.html new.html new_inotify.html page_2.html page.html secret test_inotify
05-11 11:30
查看更多