rsync+inotify配置

下载rsync源码:http://rsync.samba.org
安装rsync

#tar zxvf rsync-3.1.2.tar.gz
#cd rsync-3.1.2
#./configure
#make && make install

rsync有四种应用模式
shell模式(本地模式)
远程shell模式(利用ssh)
查询模式(列表模式)
服务器模式

#rsync SRC DST
例:
    本地模式:
  

 #rsync -av /root /tmp    复制/root目录及其文件到/tmp下
    #rsync -av /root/ /tmp  复制/root目录下的文件到/tmp下
        -a --archive 归档模式
        -v --verbose 输出详细模式信息

        
    远程模式:

    #rsync -av /root 192.168.0.99:/tmp



    列表模式:
  

  #rsync -a 192.168.0.99:/tmp 查看远程主机上的/tmp目录下的内容

            
rsync服务器端配置文件/etc/rsyncd.conf(需手动创建)包含全局参数和模块参数

uid = nobody                      #当该模块传输文件时守护进程的用户ID,默认nobody
gid = nobody                      #当该模块传输文件时守护进程的用户组ID,默认nobody
use chroot = no                   
max connections = 10              #指定模块最大并发连接数,默认为0,没有限制
strict modes = yes                #是否检查口令文件权限,yes时密码文件必须是root用户权限
pid file = /var/run/rsyncd.pid    #rsync守护进程的PID文件路径
lock file = /var/lock/rsyncd.lock #指定支持max connections的锁文件,默认是/var/run/rsyncd.conf
log file = /var/log/rsyncd.log    #rsync日志文件路径
[data]                            #定义模块名称
path = /data                      #需要备份的文件
comment = test rsync              #说明
ignore errors                     #忽略一些无关的I/O错误
read only = no                    #yes为只读,no表示可以上传文件
write only = no                   #yes表示不能下载,no表示可以下载
hosts allow = *                   #允许连接的主机
hosts deny =192.168.0.103         #禁止连接的主机
list = false                      #设定用户请求可用的模块列表时,该模块是否被列出,默认ture(列出)
uid = root                        #
gid = root                        #
auth user =backup                 #定义可连接模块的用户名,多个用逗号隔开。与系统用户无关
secrets file = /etc/rsync/server.pass #存储auth user定义的用户密码文件路径。格式“用户:密码”

 
server.pass文件

backup:123456


修改文件权限

#chmod 600 /etc/rsync/server.pass


客户端也要保存该文件但只保存密码
/etc/rsync/server.pass

123456



在服务器端开启服务

#/usr/local/bin/rsync --daemon



在客户端执行

#/usr/local/bin/rsync -vzrtopg --delete --progress --exclude "*access*" --exclude "debug*" [email protected]::data /data --password-file=/etc/rsync/server.pass



在-vzrtopg中
    v --verbose 详细输出模式
    z --compress 在传输对文对文件进行压缩处理
    r --recursi 对子目录以递归模式处理
    t --times 保持文件时间信息
    o --owner 保持文件属主信息
    p --perms 保持文件权限
    g --group 保持文件属组信息
--delete 指定以rsync服务器端为基准进行数据镜像同步
--progress 显示同步过程
--exclude 用于排除不需要传输的文件类型
[email protected]::data    表示使用backup用户对192.168.0.99的data模块备份
/data 备份文件保存的目录
--password-file=/etc/rsync/server.pass 客户机上存放密码的文件


inotify可以监控文件系统中的添加、删除、修改、移动等操作,触发rsync来备份
下载inotify-tools:http://inotify-tools.sourceforge.net/
安装inotify-tools

#tar zxvf inotify-tools-3.14.tar.gz
#cd inotify-tools-3.14
#./configure
#make && make install

在/usr/local/bin下有两个命令inotifywait和inotifywatch
inotifywait用于等待文件或文件集上的一个特定事件,可以监控任何文件和目录,也可递归监控整个目录树
inotifywatch用于收集被监控的文件系统统计数据,包括inotify事件发生多少次等信息

inotifywait的常用参数
    -m --monitor 表示保持事件始终监听
    -r --recursive 表示递归查询目录
    -q --quiet 表示打印出监控事件
    -c --event 指定要监控的事件(modify,delete,create,attrib等)
    
编写脚本来监控文件变化并完成同步
inotifyrsync.sh脚本

#!/bin/bash
#
HOST1=192.168.0.96
SRC=/data
DST1=data
user1=backup
/usr/local/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f%e'
-e modify,delete,create,attrib $SRC \
| while read file
        do
        /usr/local/bin/rsync -vzrtopg --delete --progress --password-file=/etc/r
sync/server.pass $SRC $user1@$HOST1::$DST1 &> /dev/null
        done