rsync是类unix系统下的数据镜像备份工具——remote sync,inotify 是一个 Linux特性,它监控文件系统操作,比如读取、写入和创建。两者结合可以实现服务器与客户端之间的文件实时同步。
实验逻辑图
一、安装配置rsync服务
主,备服务器检查是否安装rsync服务,一般情况下系统默认安装
[[email protected] 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/ [email protected]::data --password-file=/etc/rsyncd.pass
二、在master端安装配置inotify服务
1、查看是否支持inotify,如下说明系统支持inotify服务
[[email protected] 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同步
[[email protected] 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} [email protected]${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 [email protected]:~.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:/目录 /本地目录 抓去远端目录至本地