您的位置:首页 > 运维架构 > Linux

linux 下rsync+inotify实现实时同步

2015-06-30 17:40 513 查看
rsync是类unix系统下的数据镜像备份工具――remote sync,inotify 是一个 Linux特性,它监控文件系统操作,比如读取、写入和创建。两者结合可以实现服务器与客户端之间的文件实时同步。

实验逻辑图



一、安装配置rsync服务
主,备服务器检查是否安装rsync服务,一般情况下系统默认安装

[root@mail bin]# rpm -qa rsync
rsync-3.0.6-6.el5_11

1、首先对rsync-slave进行配置
添加配置rsync的文件,配置内容为/data/ 目录进行备份,虚拟用户syncuser,密码文件/etc/rsyncd.pass
vim /etc/rsyncd.conf

# Section 1: Global settings
port = 873
uid = root
gid = root
use chroot = no
read only = no
max connections = 7
pid file = /var/run/rsyncd.pid
log file = /var/log/rsyncd.log
hosts allow = *
transfer logging = yes
log format = %t %a %m %f %b
syslog facility = local3
timeout = 300

# Section 2: Directory to be synced
[data]
path = /data/
list = false
ignore errors = yes
auth users = syncuser
secrets file = /etc/rsyncd.pass

添加虚拟用户及密码 用于主备认证
vim /etc/rsyncd.pass
syncuser:12345
编辑完成后赋予600权限
chmod 600 rsyncd.pass
完成后启动rsync服务
rsync --daemon --config=/etc/rsyncd.conf

检查启动,rsync默认端口873
ps -ef |grep rsync |grep -v grep
netstat -lnt |grep 873
lsof -i tcp:873

2、配置rsync-master
添加密码验证文件,注意只需要密码
vim /etc/rsyncd.pass
12345
chmod 600 rsyncd.pass

测试rsync服务,将master端的/data/文件夹内容推送至slave端

rsync -avz -P /data/ syncuser@192.168.6.200::data --password-file=/etc/rsyncd.pass

二、在master端安装配置inotify服务
1、查看是否支持inotify,如下说明系统支持inotify服务

[root@mail mp3]# ls -l /proc/sys/fs/inotify/
total 0
-rw-r--r-- 1 root root 0 Apr 30 09:17 max_queued_events
-rw-r--r-- 1 root root 0 Apr 30 09:17 max_user_instances
-rw-r--r-- 1 root root 0 Apr 30 09:17 max_user_watches
2、下载安装inotify-tool工具
wget http://nchc.dl.sourceforge.net/project/inotify-tools/inotify-tools/3.13/inotify-tools-3.13.tar.gz
下载至本地,解压并安装
# tar xzvf inotify-tools-3.14.tar.gz
# cd inotify-tools-3.14
# ./configure --prefix=/usr/local/inotify
# make &&make install
3、完成安装后,至/usr/local/inotify/bin下建立inotify监控脚本,内容检测服务端的/data与客户端/data目录是否一致,不一致进行rsync同步
[root@mail etc]# vim /usr/local/inotify/bin/inotify_rsync.sh
#!/bin/bash
srcdir="/data/"
ip="192.168.6.128"
dstdir="data"

/usr/local/inotify/bin/inotifywait -mrq --timefmt '%d/%m/%y-%H:%M' --format '%T %w%f' -e modify,delete,create,attrib ${srcdir} | while read file;
do
for i in ${ip}
do
rsync -avz --progress --password-file=/etc/rsyncd.pass ${srcdir} syncuser@${i}::${dstdir} done
done
~
赋予脚本可执行权限
#chmod +x inotify_rsync.sh
后台运行
#./ inotify_rsync.sh &
4、测试,通过在mater端修改/data内容,可以查看slave端/data目录内容

另外,rsync服务可以使用ssh 通道进行传输

进行ssh免密认证
服务端命令:ssh-keygen -t rsa
scp .ssh/id_rsa.pub root@IP:~.ssh/id_rsa.pub
客户端命令:cat id_rsa.pub >> .ssh/authorized_keys
chmod 600 .ssh/authorized_keys

rsync -avz -P /本地目录 -e 'ssh -p 22' 用户@ip:/目录 推送本地目录至远端

rsync -avz -P -e 'ssh -p 22' 用户@ip:/目录 /本地目录 抓去远端目录至本地

本文出自 “滤新” 博客,请务必保留此出处http://wahehe.blog.51cto.com/8935316/1669488
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: