linux 下rsync+inotify实现实时同步

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


实验逻辑图

wKioL1WSWOrRsbMjAACrIefFLOE128.jpg

一、安装配置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/ [email protected]::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:/目录 /本地目录 抓去远端目录至本地










你可能感兴趣的:(linux)