Linux服务器利用rsync+inotify-tools实时同步备份 – inotify-tools配置篇

年后公司的事情杂七杂八的比较忙赶紧抽一点点时间把前几天未完成的rsync+inotify-tools实时同步备份的文章完结掉,要不后面忘记又得重新来过。在之前的"Linux服务器利用rsync+inotify-tools实时同步备份 - rsync配置篇"文章中,云计算优惠已经在主服务器和备份服务器分别配置rsync且可以实现数据的传输备份。

与之前rsync定时备份不同,我们这里要实现实时备份而不是定时备份,所以将会采用ino: Z 9tid C c [ V * @ 9fy-tools工具进行实F + #时备份,这一点比单纯的rsync定时备份完美很多。在这篇文章中,准备在我们的主服务器中安装inotify-tools,然后实现实时同步备份。

文章目录
隐藏
第一、准备和检查主服务器

第二、inotify-tools下载和编译安装

第三、设置环境变量? ) + | J k

第四、创建触发脚本实现同步

第五、设置开机自动启动

第六、rsync+inotify-tools实时备份小结

第一、准备和检查主P 6 N F M . 4服务器

这篇文章中,云计算优惠全部在主服务器中配置,我们需要先检查当前服务器是否支持inotify,一般还是支持的,我们- . S P F M J f选择的系统是CentOS6以上版本,内核只要在2.6.13以上就没有问题。

1、检查是否支持

ll /proc/sys/fs/iQ [ 9 z t ?notifq l { ` zy

通过上面命令检查,如果能看到上图所示的三行,以及uname -r检测看到内核在2.6.13以上就没有问题。

2、安装必要工具包

yum install make gcc gcc-c++ -y

我们需要在inotify-tools配置安装之前将必^ h . B要的工具包安装,然后才可以编译。

第二& Q j { S p +、inoti2 D h v Ofy-tools下载和编译安装

cd /+ g Q o N , K vu# r ; fsr/local/src
wget https://soft._ s x A : Q Citbulu_ j {.com/backup/inotify-tools-3.14.tar.gz
tar -zxvf inotify-tools-3.14.tar.gz
cd inotify-tools-3.14
./ci ) 6 s fonfigure --prefix=B z L g Q T/usr/local/inotify
make
makeq } A V q L install

我们下载inotify-tools工具包,然后解压和编译安装。

第三、设置环境变量

echo "PATH=/usA & : Rr/local/inotify/bin:$PATH" >>/etc/profile.d/inotify.sh
source /etc/profile.d/inotify.sh
echo "/usr/lO z u t X w ocal/inotify/Y 1 y M | T Slib" >/etc/ld.so.conf.d_ t ` _ ( /inotify~ # c 8 ` ~ @ }.conf
ln -s /usr/local/inotify/include /usr/include/inotify

修改配置参数:

vi /etc/syscte e = Yl.conf

打开文件,然后在最: 2 + C N . l n后添加几行:

fs.inotify.max_queued_events| @ 1 @ 4 H =99999999
fs.inotify.mS H {ax_user_watches=99999999
fs.inotify.max_user_instances=65535

然后保存退出x { i (

第四、创建触发脚本实现同步

vi /usr/local/inotify/rsync.sh

新建同步触发脚本文件,然后添加脚本:

#!/bin/sh
#同步主服务器网站文件位置
srcdir=/home/wwwroot/itbulu.com
dstdir=www.itbulu.com
exclF ` Vudedir=/usr/local/ine 1 . h s O F Jotify/excludi N _ Y e.list
rsyncuser=www.itbulu.com_user
rsyncpassdir=/etc/* p k s } )passwd.txt
#备份服务器IP地址
dstip="22.22.22.22"
for ip in $dstip
do
rsync -avH --port=873b # , --progress --delete --exclude-from=$excludedir $src5 | * O c s T I }dir $rsyncuser@$ip::$dstdir --password-file=$rY ) k j & AsyncpassdiB M p / # Gr
done

/usr/local6 @ 5/inotify/bin/inotifywait -mrN # ~ | M b $ v Rq --ti# U X lmefmt '%d/%m/%- { My %~ N B & ~ a ,H:%M' --format '%T %w%f%e' -e close_write,modify,delete,create,attrib,move $srcdir | while read file
do
for ip in $dstip
do
rsync -avH --port=873 --progress --delete --exclude-from=$excludedir $srcdir $rsyncuser@$ip::$dstdir --password-file=$rsyncpassdir
echo " ${l s e ) y ~ gfile} was rsynced" >> /tmp/rsync.log 2>&1
done
done

根据我们主服务器备份的目录以及备份服务器的IP地址对应修改。这里还需要注意一个目录:

/usr/local/inotify/exclude.list

这个可以用来排除不参与同步的目录,可以对应位置创建文件,然后文件中一行写一个:

images/

这样表示不备份这个图片文件夹。

chmod +x /usr/local/inotify/rsS ) q t M Xync.sh

然后我们对配置好的rsync.sh文件授C m !权。dstdir、rsyncuser、rsyncpassdir等配置文件要对应备份服务器之前设置的模块参数。

第五、设置开机自动启动

vi /etc/rc.4 ^ i k ) } wd/rc.local; 4 U X , (

开机启动设置,添加脚本:

sh /usr/local/inotify/rsK . y h g ; b pync.sh &

添加到最后一样,然后保存退出。重启服务器生效,这样,我们在主服务器添加文件,删除文件,然后在备份服务器中可以实现实时同步备份。

第六、S w D X I u y Mrsync+inotify-tooll h e | z 9s实时备份小结

1、云计算优惠从开始单独的采用rsync,然后发现弊端之后,决定研究采用rsyn5 u j z 4 bc+inotify-tools方式,通过j - K Y ` q 9 = )文章的记录以及实验是可以实现的,云计算优k Q O [ e d H惠记录下来以备日后使用。

2、实时同步相比定时会好很多,这样不用担心万一定时时间差的问题,以及rsync全盘对比文件产生的占用资源问题。

3、本文有参考:http://www.osyunwei.com/archives/7435.html以及其他网上的文章整理出来的,感[ y / z K % @谢这些网友的分享。