测试环境如下:

inotify-slave IP : 172.16.0.222

inotify-master IP : 172.16.0.233

对两台机的要求:

安装依赖包gcc: yum install gcc –y

关闭disabled

开放端口873

一、inotify slave部署

1、  安装rsync:

 $ sudo yum install rsync –y

2、  添加用户和模块目录,并更改用户和组

$ sudo useradd rsync –s /sbin/nologin –M

$ sudo mkdir /home/jeff/back

$ sudo chown rsync.rsync /home/jeff/back/

3、  修改配置文件/etc/rsyncd.conf,内容如下:

uid = rsync
gid = rsync
use chroot = no
max connections = 200
timeout = 300
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
log file = /var/log/rsyncd.log [backup]
path = /home/jeff/back/
ignore errors
read only = no
write only = no
list = false
hosts allow = 10.0.0.0/24
hosts deny = 0.0.0.0/32
auth users = rsync_backup
secrets file = /etc/rsync.password

Tips: ubuntu系统的文件路径一般为/usr/share/doc/rsync/examples/rsyncd.conf,可以创建软链接,结果都一样。创建方法如下:

$ sudo ln -s /usr/share/doc/rsync/examples/rsyncd.conf  /etc/rsyncd.conf

4、  配置虚拟用户的密码文件

$ sudo -i
# echo ‘rsync_backup:jeff’ >>/etc/rsync.password
# exit
$ sudo chmod 600 /etc/rsync.password
$ sudo rsync --daemon
$ sudo ss -tulpn |grep rsync

5、  加入开机启动

$ sudo -i
# echo ‘/usr/bin/rsync --daemon’ >>/etc/rc.local
# exit

二、部署服务器(inotify-master)

1、  查看系统是否支持inotity

ll /proc/sys/fs/inotify 

# 如果显示max_queued_events、max_user_instances、max_user_watches就证明支持inotify

2、  安装inotify 3.14

$ wget http://github.com/downloads/rvoicilas/inotify-tools/inotify-tools-3.14.tar.gz
$ tar zxf inotify-tools-3.14.tar.gz
$ cd inotify-tools-3.14 $ sudo ./configure --prefix=/usr/local/inotify
$ sudo make && sudo make install

3、  创建备份目录

$ mkdir /home/jeff/back/

4、  创建rsync服务的密码文件

$ sudo -i
# echo “jeff” >/etc/rsync.password //此处只写密码即可
# chmod 600 /etc/rsync.password
# exit

5、  编写执行脚本

$ sudo vim /usr/local/inotify.sh

[/usr/local/inotify.sh]
#!/bin/bash
host01=172.16.0.222 //inotify-slaver的IP地址
src=/home/jeff/back //本地监控的目录
dst=backup //inotify-slave的服务模块名
user=rsync_backup //inotify-slave的rsync虚拟用户
rsync_passfile=/etc/rsync.password //本地调用的rsync密码文件
inotify_home=/usr/local/inotify //inotify安装目录 #judge
if [ ! -e "$src" ] \
|| [ ! -e "${rsync_passfile}" ] \
|| [ ! -e "${inotify_home}/bin/inotifywait" ] \
|| [ ! -e "/usr/bin/rsync" ];
then
echo "Check File and Folder"
exit 9
fi ${inotify_home}/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f' -e close_write,delete,create,attrib $src \
| while read file
do
# rsync -avzP --delete --timeout=100 --password-file=${rsync_passfile} $src $user@$host01::$dst >/dev/null 2>&1
cd $src && rsync -aruz -R --delete ./ --timeout=100 $user@$host01::$dst --password-file=${rsync_passfile} >/dev/null 2>&1
done
exit 0

6、将脚本加入后台执行

$ sh inotify.sh &

7、  加入开机启动

$ sudo -i
# echo ‘/bin/bash /home/jeff/inotify.sh &’ >>/etc/rc.local
# exit

三、测试实时同步(部署前建议先运行这一步验证,然后再执行第二步)

$ sudo rsync  -avz /home/jeff/back/test.txt rsync_backup@10.0.0.22::backup --password-file=/etc/rsync.password

四、改变SSH的默认端口为1234时,rsync的连接方法如下

# 此处用-e 'ssh -p 3333'来指定SSH连接端口
$ /usr/bin/rsync -av /backup/* -e 'ssh -p 3333' root@10.0.0.22:/backup/

PS:操作步骤参考自 http://jingyan.baidu.com/article/656db918ee2f13e380249c4d.html

CentOS 7 rsync+inotify实现实时同步的更多相关文章

  1. centos 配置rsync+inotify数据实时同步2

    一.Rsync服务简介 1. 什么是Rsync 它是一个远程数据同步工具,它在同步文件的同时,可通过LAN/WAN快速同步多台主机间的文件.Rsync使用所谓的“rsync算法”来使本地和远程两个主机 ...

  2. centos 配置rsync+inotify数据实时同步

    何为rsync? 定义: rsync是一个开源的快速备份工具,可以在不同主机之间镜像同步整个目录树,支持增量备份,保持链接和权限,非常适用于异地备份 何为源端和发起端? 在远程同步过程中,负责发起rs ...

  3. linux rsync +inotify 实现 实时同步

    前言:     rsync可以实现触发式的文件同步,但是通过crontab守护进程方式进行触发,同步的数据和实际数据会有差异,而inotify可以监控文件系统的各种变化,当文件有任何变动时,就触发rs ...

  4. rsync + inotify 数据实时同步

    一.rsync介绍 rsync英文全称为Remote synchronization,从软件的名称就可以看出来,Rsync具有可是本地和远程两台主机之间的数据快速复制同步镜像.远程备份的功能,这个功能 ...

  5. rsync+inotify实现实时同步案例--转

    转自:http://chocolee.blog.51cto.com/8158455/1400596 随着应用系统规模的不断扩大,对数据的安全性和可靠性也提出的更好的要求,rsync在高端业务系统中也逐 ...

  6. Rsync+inotify实现实时同步

    1.1 inotify介绍 inotify是一种强大的.细粒度的.异步的文件系统事件控制机制.linux内核从2.6.13起,加入了inotify支持,通过inotify可以监控文件系统中添加.删除. ...

  7. rsync+inotify实现实时同步案例【转】

    1.1 inotify介绍 inotify是一种强大的.细粒度的.异步的文件系统事件控制机制.linux内核从2.6.13起,加入了inotify支持,通过inotify可以监控文件系统中添加.删除. ...

  8. rsync+inotify实现实时同步案例

    转自:http://chocolee.blog.51cto.com/8158455/1400596 随着应用系统规模的不断扩大,对数据的安全性和可靠性也提出的更好的要求,rsync在高端业务系统中也逐 ...

  9. rsync简介与rsync+inotify配置实时同步数据

    rsync简介 rsync是linux系统下的数据镜像备份工具.使用快速增量备份工具Remote Sync可以远程同步,支持本地复制,或者与其他SSH.rsync主机同步. rsync特性 rsync ...

随机推荐

  1. Swap file "/etc/.hosts.swp" already exists! [O]pen Read-Only, (E)dit anyway, (R)ecover, (D)elete it,

    非正常关闭vi编辑器时会生成一个.swp文件 非正常关闭vi编辑器时会生成一个.swp文件 关于swp文件 使用vi,经常可以看到swp这个文件,那这个文件是怎么产生的呢,当你打开一个文件,vi就会生 ...

  2. php输入输出

    php是服务器脚本语言,js是客户端脚本语言 php用表单接收数据,echo 输出数据,$定义变量. <?php echo $_POST["sub"]; // POST后是表 ...

  3. iOS JSON 和 Mode l转换

    MJExtension  是我们项目开发常用的一个第三方框架  很好用. https://github.com/CoderMJLee/MJExtension 映射 json  value key  直 ...

  4. 【leetcode刷题笔记】Insertion Sort List

    Sort a linked list using insertion sort. 题解:实现链表的插入排序. 要注意的地方就是,处理链表插入的时候尽量往当前游标的后面插入,而不要往前面插入,后者非常麻 ...

  5. 【Flask】Column常用参数

    ### Column常用参数:1. primary_key:设置某个字段为主键.2. autoincrement:设置这个字段为自动增长的.3. default:设置某个字段的默认值.在发表时间这些字 ...

  6. 《机器学习实战》学习笔记第五章 —— Logistic回归

    一.有关笔记: 1..吴恩达机器学习笔记(二) —— Logistic回归 2.吴恩达机器学习笔记(十一) —— Large Scale Machine Learning 二.Python源码(不带正 ...

  7. springmvc接受表单多条数据的值

    点击下面链接查看具体内容: http://blog.csdn.net/lutinghuan/article/details/46820023

  8. Neutron Messaging Callback System

    callback system 用在进程内部通信,Messaging Callback System是给进程间通信.为了agent不通过RPC就能得到resource的变化. 目前用在: QoS po ...

  9. linux学习-环境变量与文件查找

  10. AngularJs 相应回车事件

    最近做项目,要用到AngularJs,之前也有用过一点点,但仅限于数据的绑定,这次项目要整个前端需要使用这个框架,可能是不熟悉的原因,感觉这代码搞起来非常的不便利,:现总结一个响应回车事件: < ...