rsync+inotify-系统文件实时同步
inotify是Linux下的一个文件系统事件监控机制(简单说就是用于监控某个文件夹的改动),
作为dnotify的有效替代。inotify是一种强大的、细粒度的、异步的机制,它满足各种各样
的文件监控需要。在单独使用rsync同步时,每次同步它会把全部的文件读取一遍,
而inotify+rsync同步是触发式同步。假设被镜像端IP为192.168.1.100,镜像端IP为192.168.1.200。
一、被镜像(同步)端
linux内核2.6.13之后就支持inotify了,确认方法:
ls /proc/sys/fs/inotify
如果有以下三项就支持:
max_queued_events max_user_instances max_user_watches
安装rsync:
yum install rsync
安装inotify:
官网:https://github.com/rvoicilas/inotify-tools
cd /tmp
wget http://github.com/downloads/rvoicilas/inotify-tools/inotify-tools-3.14.tar.gz
tar -zxvf inotify-tools-3.14.tar.gz
cd inotify-tools-3.14
./configure
make
make install
默认安装到/usr/local/bin目录。
建立rsync密码文件:
vi /root/rsyncpass
输入密码:
123456
设置权限为600:
chmod 600 /root/rsyncpass
创建同步脚本:
vi /root/rsync.sh
输入:
#!/bin/bash
src=/home/www/web001
des=user@192.168.1.200::web
/usr/local/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f' \
-e modify,delete,create,attrib ${src} | while read x
do
/usr/bin/rsync -avz --delete --progress $src $des --password-file=/root/rsyncpass &&
echo "$x was rsynced" >> /var/log/rsync.log
done
为脚本加执行权限:
chmod +x /root/rsync.sh
在rc.local加入自启动:
echo "/root/rsync.sh" >> /etc/rc.local
二、镜像(同步)端
安装rsync:
yum install rsync
编辑配置文件:
vi /root/rsyncd.conf
输入:
uid = root
gid = root
use chroot = no
max connections = 10
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
log file = /var/log/rsyncd.log
hosts allow = *
[web]
path = /home/www/web001
read only = no
list = no
auth users = user
secrets file = /root/rsync.pass
建立密码文件:
vi /root/rsync.pass
输入:
user:123456
格式为“用户名:密码”。
设置权限为600:
chmod 600 /root/rsync.pass
建立保存同步文档的目录:
mkdir /home/www/web001
后台启动rsync:
/usr/bin/rsync --daemon --config=/root/rsyncd.conf
在被镜像端上运行同步脚本:
作为dnotify的有效替代。inotify是一种强大的、细粒度的、异步的机制,它满足各种各样
的文件监控需要。在单独使用rsync同步时,每次同步它会把全部的文件读取一遍,
而inotify+rsync同步是触发式同步。假设被镜像端IP为192.168.1.100,镜像端IP为192.168.1.200。
一、被镜像(同步)端
linux内核2.6.13之后就支持inotify了,确认方法:
ls /proc/sys/fs/inotify
如果有以下三项就支持:
max_queued_events max_user_instances max_user_watches
安装rsync:
yum install rsync
安装inotify:
官网:https://github.com/rvoicilas/inotify-tools
cd /tmp
wget http://github.com/downloads/rvoicilas/inotify-tools/inotify-tools-3.14.tar.gz
tar -zxvf inotify-tools-3.14.tar.gz
cd inotify-tools-3.14
./configure
make
make install
默认安装到/usr/local/bin目录。
建立rsync密码文件:
vi /root/rsyncpass
输入密码:
123456
设置权限为600:
chmod 600 /root/rsyncpass
创建同步脚本:
vi /root/rsync.sh
输入:
#!/bin/bash
src=/home/www/web001
des=user@192.168.1.200::web
/usr/local/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f' \
-e modify,delete,create,attrib ${src} | while read x
do
/usr/bin/rsync -avz --delete --progress $src $des --password-file=/root/rsyncpass &&
echo "$x was rsynced" >> /var/log/rsync.log
done
为脚本加执行权限:
chmod +x /root/rsync.sh
在rc.local加入自启动:
echo "/root/rsync.sh" >> /etc/rc.local
二、镜像(同步)端
安装rsync:
yum install rsync
编辑配置文件:
vi /root/rsyncd.conf
输入:
uid = root
gid = root
use chroot = no
max connections = 10
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
log file = /var/log/rsyncd.log
hosts allow = *
[web]
path = /home/www/web001
read only = no
list = no
auth users = user
secrets file = /root/rsync.pass
建立密码文件:
vi /root/rsync.pass
输入:
user:123456
格式为“用户名:密码”。
设置权限为600:
chmod 600 /root/rsync.pass
建立保存同步文档的目录:
mkdir /home/www/web001
后台启动rsync:
/usr/bin/rsync --daemon --config=/root/rsyncd.conf
在被镜像端上运行同步脚本:
/root/rsync.sh &
参考文章:
http://denight.leanote.com/post/Svn%E8%87%AA%E5%8A%A8%E6%9B%B4%E6%96%B0Web%E7%9B%AE%E5%BD%95
http://www.live-in.org/archives/1144.html
http://www.smsyun.com/home-index-page-id-33.html
正文部分到此结束
版权声明:除非注明,本文由( chao )原创,转载请保留文章出处