rsync+inotify同步每日新增的文件夹

rsync+inotify已经实现了文件夹下的内容同步

例如:
监控 /var/logs/文件夹,该文件夹下每日生成2016-07-19的日期格式的文件夹

问题:
当第二天开始,/var/logs/下新增了一个2016-07-20文件夹的时候,rsync+inotify却没有进行同步

必须手动kill掉rsync的进程,然后重新启动一次,就可以同步2016-07-20的文件夹了。

解决:
请问如何实现rsync+inotify自动同步每日新增的文件夹

下面是执行的shell脚本,网上抄的
rsync_watch.sh

#!/bin/bash
# 需要同步的源路径
src=/var/logs/
# 目标服务器上 rsync --daemon 发布的名称
des=log
rsync_passwd_file=/etc/rsyncd.passwd            # rsync验证的密码文件
ip1=192.168.100.2                               # 目标服务器1
user=root                                       # rsync --daemon定义的验证用户名
cd ${src}
/usr/bin/inotifywait -mrq --format  '%Xe %w%f' -e modify,create,delete,attrib,close_write,move ./ | while read file         
# 把监控到有发生更改的"文件路径列表"循环
do
        INO_EVENT=$(echo $file | awk '{print $1}')      # 把inotify输出切割 把事件类型部分赋值给INO_EVENT
        INO_FILE=$(echo $file | awk '{print $2}')       # 把inotify输出切割 把文件路径部分赋值给INO_FILE
        echo "-------------------------------$(date)------------------------------------"
        echo $file
        #增加、修改、写入完成、移动进事件
        #增、改放在同一个判断,
        if [[ $INO_EVENT =~ 'CREATE' ]] || [[ $INO_EVENT =~ 'MODIFY' ]] || [[ $INO_EVENT =~ 'CLOSE_WRITE' ]] || [[ $INO_EVENT =~ 'MOVED_TO' ]]         # 判断事件类型
        then
                echo 'CREATE or MODIFY or CLOSE_WRITE or MOVED_TO'
                rsync -avzcR --password-file=${rsync_passwd_file} $(dirname ${INO_FILE}) ${user}@${ip1}::${des}

        fi
        #删除、移动出事件
        if [[ $INO_EVENT =~ 'DELETE' ]] || [[ $INO_EVENT =~ 'MOVED_FROM' ]]
        then
                echo 'DELETE or MOVED_FROM'
                rsync -avzR --delete --password-file=${rsync_passwd_file} $(dirname ${INO_FILE}) ${user}@${ip1}::${des}
        fi
        #修改属性事件 指 touch chgrp chmod chown等操作
        if [[ $INO_EVENT =~ 'ATTRIB' ]]
        then
                echo 'ATTRIB'
                if [ ! -d "$INO_FILE" ]
                then
                        rsync -avzcR --password-file=${rsync_passwd_file} $(dirname ${INO_FILE}) ${user}@${ip1}::${des}
                fi
        fi
done
阅读 3.6k
1 个回答

也许是inotify的事情没触发?

我觉得如果只是基于“每日”的同步,cron + rsync更简单粗暴。

也许是因为我还没开始学习inotify。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题