Centos文件同步自动工具sersync(需要和rsync配合使用)
这篇文章是接上篇rsync进行同步(https://www.cnblogs.com/pinpin/p/14306455.html),本文主要是用sersync工具,实时触发rsync进行同步
1- 先来看下服务器内核是否支持inotify,我用的centos7默认是支持的,如果不支持需要安装配置
命令:
[root@localhost sugon]#ll /proc/sys/fs/inotify #列出文件目录,出现下面的内容,说明服务器内核支持inotify
注意:inotify默认内核参数值有点小,可以对inotify默认参数进行修改,我这里做测试不做修改,修改方法在后文
2- 安装sersync
下载sersync:https://sersync.googlecode.com/files/sersync2.5.4_64bit_binary_stable_final.tar.gz
下载后我们将文件上传到/usr/local/src中,对文件进行解压缩
命令: [root@localhost sugon]# cd /usr/local/src #切换到sersync目录 [root@localhost src]# tar zxvf sersync2.5.4_64bit_binary_stable_final.tar.gz #解压 [root@localhost src]# mv GNU-Linux-x86 /usr/local/sersync #将GNU-Linux-x86文件移动到/usr/local/sersync中
3- 配置sersync
命令: [root@localhost src]# cd /usr/local/sersync #切换/usr/local/sersync目录 [root@localhost sersync]# cp confxml.xml confxml.xml-bak #备份文件 [root@localhost sersync]# vi confxml.xml #修改文件信息
修改的代码如下:
<delete start="true"/> <createFolder start="true"/> <createFile start="true"/> <closeWrite start="true"/ <localpath watch=/var/www/html">: #本地监听目录,源服务器同步目录 <remote ip="192.168.1.163" name="rsync_test "/>: #服务端IP地址和备份目录 <auth start="true" users="ursync" passwordfile="/etc/rsync_test.passwd"/>#users=" ursync":服务端模块rsync认证用户名;passwordfile="/etc/rsync_test.passwd ":服务端rsync认证用户的密码存放路径 failLog path="/tmp/rsync_fail_log.sh" #脚本运行失败日志记录 start="true" schedule=600 #设置start为true,每隔600分钟执行一次全盘同步
4- 设置sersync监控开机自动执行
命令: [root@localhost sersync]# vi /etc/rc.d/rc.local #打开文件设置开机自动运行脚本,添加/usr/local/sersync/sersync2 -d -r -o /usr/local/sersync/confxml.xml [root@localhost sersync]# chmod +x /etc/rc.d/rc.local #添加可执行权限,注意,不添加将无法开机执行
5- 添加脚本监控sersync,并定时检查,如果不在执行,重新执行
命令: [root@localhost sersync]# vi /home/crontab/check_sersync.sh #编辑,代码在下文
[root@localhost sersync]# chmod +x /home/crontab/check_sersync.sh #修改文件权限
[root@localhost sersync]# vi /etc/crontab #添加定时任务,添加内容*/10 * * * * root /home/crontab/check_sersync.sh > /dev/null 2>&1
[root@localhost sersync]# service crond reload #重新加载服务
check_sersync.sh内容
#!/bin/sh sersync="/usr/local/sersync/sersync2" confxml="/usr/local/sersync/confxml.xml" status=$(ps aux |grep 'sersync2'|grep -v 'grep'|wc -l) if [ $status -eq 0 ]; then $sersync -d -r -o $confxml & else exit 0; fi
修改inotify默认参数(inotify默认内核参数值太小):这边我没有遇到报错,完全是先将牛人的解决方法先拷贝过来
先查看系统默认参数值:
[root@localhost sersync]# sysctl -a | grep max_queued_events #结果:fs.inotify.max_queued_events = 16384 [root@localhost sersync]# sysctl -a | grep max_user_watches #结果:fs.inotify.max_user_watches = 8192 [root@localhost sersync]# sysctl -a | grep max_user_instances #结果:fs.inotify.max_user_instances = 128
我们使用命令修改:
[root@localhost sersync]# sysctl -w fs.inotify.max_user_instances=65535 [root@localhost sersync]# sysctl -w fs.inotify.max_queued_events=99999999
参数说明:
max_queued_events:设置inotify实例事件队列可容纳的事件数量,inotify队列最大长度,如果值太小,会出现" Event Queue Overflow "错误,导致监控文件不准确
max_user_watches:设置inotifywait或inotifywatch命令可以监视的文件数量。要同步的文件包含多少目录,可以用:find /home/www.jb51.net -type d | wc -l 统计,必须保证max_user_watches值大于统计结果
max_user_instances:设置每个用户可以运行inotifywait或inotifywatch命令的进程数
永久生效方法如下:(建议采用此方法)
vim /etc/sysctl.conf
fs.inotify.max_user_watches = 9999999(后面值根据实际情况可自行调整)
fs.inotify.max_user_instances = 65535
添加并运行/sbin/sysctl -p即可