设为首页 收藏本站
查看: 240|回复: 0

[经验分享] rsync+inotify实现同步数据

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-7-6 09:38:39 | 显示全部楼层 |阅读模式
1.虚拟机:192.168.20.140 server端

          192.168.20.137 client端


2.下载安装rsync
    下载:tar -zxvf rsync-3.1.1.tar.gz
          cd     rsync-3.1.1
          ./configure --prefix=/usr/local/rsync

           make && make install


3.配置rsync的主配置文件。
        vim /etc/rsyncd.conf (这里要注意,是rsyncd.conf,不是rsync.conf,不然会读取不到)

        
uid = root            #/运行rsync守护进程的用户名
gid = root
use chroot = no        #/不使用chroot
max connections = 0    #/不限制最大数
log file=/var/log/rsyncd.log     #日志记录文件的存放位置
pid file=/var/run/rsyncd.pid     #pid文件的存放位置   
lock file=/var/run/rsyncd.lock    #锁文件的存放位置

[21dir]      #/认证模块,client端是要认证的,要统一
path = /home/rsync/   #/同步路径
comment = rsync from 192.168.20.140   #/rsync 服务来自server端
read only = no   
list = no   
auth users = rsyncuser    #/认证用户名
secrets file = /etc/21.pas    #/用户密码认证


3.server端的密码表

    vim /etc/21.pas

     rsyncuser:123456
设置权限防止非root的修改密码
    chmod 600 /etc/21.pas

4.启动rsync服务
/usr/local/rsync/bin/rsync  --port=873 --address=192.168.20.140 --daemon
netstat -tlunp 查看rsync的873端口是否开启

5.client端
     vim /etc/21.pas
    123456  #/这里只需要密码就可以,能跟server端匹对上
   chmod 600 /etc/21.pas

6.测试是否同步(用客户端测试)
    /usr/bin/rsync -avH --delete --progress --password-file=/etc/21.pas  /home/rsync/ rsyncuser@192.168.20.140::21dir

7.Server端下载安装inotify服务
     tar xzvf inotify-tools-3.14.tar.gz
     cd inotify-tools-3.13
     ./configure  --prefix=/usr/local/inotify
     make
     make install



8.监控脚本
#!/bin/bash
#function:rsync 192.168.20.140 to 192.168.20.137
#

if [ ! -f /etc/21.pas ]
then
        echo "123456" > /etc/21.pas
        chmod 600 /etc/21.pas
fi

log=/usr/local/inotify/logs/rsync.log
path="/home/rsync"
host="192.168.20.137"
module="21dir"

/usr/local/inotify/bin/inotifywait -mr --timefmt '%d/%m/%y %H:%M' --format '%T %w %f' -e close_write
,modify,delete,create,attrib $path |  while read DATE TIME DIR FILE; do
        FILECHANGE=${DIR}${FILE}
      /usr/bin/rsync -avH --delete  --progress --password-file=/etc/21.pas $path  --exclude-from="/usr/local/inotify/logs/rules.txt" rsyncuser@$host::$module && echo "At ${TIME} on ${DATE}, file $FILECHANGE was backed up via rsync" >> $log


done

exit 0

9.添加脚本权限

    chmod +x inotify.sh

10.执行脚本
    sh inotify.sh
   

11.详解命令

/usr/local/bin/inotifywait -mrq -e modify,delete,create,attrib ${src}
-m 是保持一直监听
-r 是递归查看目录
-q 是打印出事件


-e close_write,modify,delete,create,attrib 是指 “监听 创建 移动 删除 写入 权限” 事件

/usr/bin/rsync -avH --delete  --progress --password-file
-a 存档模式
-H 保存硬连接
-delete 删除于多余文件

--password-file 密码文件

12.同步文件
    /usr/bin/rsync -vzrtopg --progress rsyncuser@192.168.20.140::21dir/(可以在填单一的文件名) /home/rsync/ (同步到client端的路径)
   

13.删除文件
    /usr/bin/rsync -avH --delete --progress --password-file=/etc/21.pas  /home/rsync/ rsyncuser@192.168.20.140::21dir(通过client端删除server端/home/rsync的文件中不一样的文件)


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-83692-1-1.html 上篇帖子: Linux服务器磁盘占满问题解决 下篇帖子: 配置RedHat 6系统YUM网易源
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表