不啰嗦,不介绍rsync用法,直接实现使用
rsyncd.conf配置
# vim /etc/rsyncd.conf
port=873
log file=/var/log/rsync.log
pid file=/var/run/rsyncd.pid
[test]
path=/home/test_server
use chroot=true
max connections=4
read only=no
list=false
uid=root
gid=root
auth users=test
secrets file=/etc/rsync.pass
hosts allow=192.168.0.31
auth users 与系统用户没有任何关系,只在这里指定使用.
secrets file 是auth users这个用户的信息,内容格式 : test:123456
,为了安全,将此文件更改为600的权限.
启动
# rsync --daemon
# ss -lntp |grep rsync
可以查看到rsync服务的873的端口
安装inotify-tools
# wget http://github.com/downloads/rvoicilas/inotify-tools/inotify-tools-3.14.tar.gz
# yum install –y gcc
# mkdir /usr/local/inotify
# tar -xzf inotify-tools-3.14.tar.gz
# cd inotify-tools-3.14
# ./configure --prefix=/usr/local/inotify/
# make && make install
# echo 'export PATH=/usr/local/inotify/bin/:$PATH' >> /etc/profile
# . /etc/profile
# echo '/usr/local/inotify/lib' >> /etc/ld.so.conf --加载库文件
# ldconfig
# ln -s /usr/local/inotify/include /usr/include/inotify
常用参数
-m —始终保持监听状态,默认触发事件即退出
-r —递归查询目录
-q —打印出监控事件
-e —定义监控的事件,可用参数:
access —访问文件
modify —修改文件
attrib —属性变更
open —打开文件
delete —删除文件
create —新建文件
move —文件移动
—fromfile —从文件读取需要监视的文件或者排除的文件,一个文件一行,排除的文件以@开头
—timefmt —时间格式
—format —输出格式
—exclude —正则匹配需要排除的文件,大小写敏感
—excludei —正则匹配需要排除的文件,忽略大小写
%y%m%d %H%M —年月日时钟
%T%w%f%e —时间路径文件名状态
查看系统是否支持
使用ll /proc/sys/fs/inotify
命令,是否有以下三条信息输出,如果没有表示不支持。
-rw-r--r-- 1 root root 0 Dec 11 15:23 max_queued_events
-rw-r--r-- 1 root root 0 Dec 11 15:23 max_user_instances
-rw-r--r-- 1 root root 0 Dec 11 15:23 max_user_watches
max_queued_events
表示调用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可监控的最大目录数量。如果监控的文件数目巨大,需要根据情况,适当增加此值的大小。
编辑同步脚本
#!/bin/bash
/usr/local/inotify/bin/inotifywait -mrq -e modify,create,move,delete,attrib /home/test31/test31 | while read events
do
rsync -a --bwlimit=200 /home/test31/test31 test@192.168.0.30::test --password-file=/home/password.txt
echo "`date +'%F %T'` 出现事件:$events" >> /tmp/rsync.log 2>&1
done
--password-file
这个参数用来写auth users的密码,权限也改为600
--bwlimit=200
这个参数限制传输速率为200kb,若不限制,会导致巨大的CPU消耗.
当然,也可以在目标机器上也写一个这样的脚本,用来实现双向同步