rsync+inotify 实现实时同步
inotify:这个可以监控文件系统中的添加,修改,删除,移动等事件
inotify的特性需要linux内核2.6.13以上的支持
[root@test1 inotify-tools-3.13]# uname -r
2.6.-.el6.i686 #支持 还需要看看是否安装了inotify
[root@test1 inotify-tools-3.13]# ll /proc/sys/fs/inotify/
total #这个里面的东西是inotify的接口用于限制内存大小
-rw-r--r-- root root Aug : max_queued_events #表示调用init时分配到instance中排队的event的最大数目,超出就会被丢弃
-rw-r--r-- root root Aug : max_user_instances #表示一个real id user 可创建instance的最大数目
-rw-r--r-- root root Aug : max_user_watches #表示inotify可监控的最大目录文件上限,如果目录文件过多可以把这个值调大点
光有inotify还不够,还要安装inotify-tools
[root@test1 ~]# wget http://sourceforge.net/projects/inotify-tools/files/latest/download/inotify-tools-3.13.tar.gz
[root@test1 ~]# tar zxf inotify-tools-3.13.tar.gz
[root@test1 ~]# cd inotify-tools-3.13
[root@test1 ~]#./configure
[root@test1 ~]#make && make install
[root@test1 inotify-tools-3.13]# ll /usr/local/bin/inotifywa*
-rwxr-xr-x. root root Aug : /usr/local/bin/inotifywait #用于等待文件或者文件集上的特定事件
-rwxr-xr-x. root root Aug : /usr/local/bin/inotifywatch #收集监控的文件系统统计数据,包括inotify事件发生多少次
/usr/local/bin/inotifywait
-m:始终保持事件监控状态
-r:递归查询目录
-q:打印监控事件
-e:指定要监控的事件,常见事件有,modify,delete,create和attrib
这个还可以一次同步到多台服务器,用多台rsync服务端作为客户端,在另外一台服务器上监控一个目录,当目录里面有文件发生状态和属性改变事件,就会自动触发同步到多台服务器上
rsync_inotify.sh
#!/bin/bash
#需要同步的服务器地址
Dst_Host=192.168.1.20 #源文件目录
Src_Dir=/webserver/ #需要同步的远程服务器上的模块名
Dst_Module=WEBSERVER #远程服务器上的模块认证用户
Module_UserName=sheng #rsync命令的绝对路径
Rsync_Pwd=`whereis rsync | awk '{print $2}'` /usr/local/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' \
--format '%T %w%f %e' \
-e modify,delete,create,attrib $Src_Dir \
| while read file
do
${Rsync_Pwd} -vzrtopg --delete --password-file=/etc/rsyncd.pass $Src_Dir $Module_UserName@$Dst_Host::$Dst_Module
echo "${file} was rsyncd!" >> /var/log/rsync_inotify.log
done
同样也可以用这个命令扑捉到文件改变的事件,运行别的程序,比如nginx nginx.conf文件一改变就重新加载
rsync+inotify 实现实时同步的更多相关文章
- linux rsync +inotify 实现 实时同步
前言: rsync可以实现触发式的文件同步,但是通过crontab守护进程方式进行触发,同步的数据和实际数据会有差异,而inotify可以监控文件系统的各种变化,当文件有任何变动时,就触发rs ...
- rsync + inotify 数据实时同步
一.rsync介绍 rsync英文全称为Remote synchronization,从软件的名称就可以看出来,Rsync具有可是本地和远程两台主机之间的数据快速复制同步镜像.远程备份的功能,这个功能 ...
- rsync+inotify实现实时同步案例--转
转自:http://chocolee.blog.51cto.com/8158455/1400596 随着应用系统规模的不断扩大,对数据的安全性和可靠性也提出的更好的要求,rsync在高端业务系统中也逐 ...
- Rsync+inotify实现实时同步
1.1 inotify介绍 inotify是一种强大的.细粒度的.异步的文件系统事件控制机制.linux内核从2.6.13起,加入了inotify支持,通过inotify可以监控文件系统中添加.删除. ...
- rsync+inotify实现实时同步案例【转】
1.1 inotify介绍 inotify是一种强大的.细粒度的.异步的文件系统事件控制机制.linux内核从2.6.13起,加入了inotify支持,通过inotify可以监控文件系统中添加.删除. ...
- rsync简介与rsync+inotify配置实时同步数据
rsync简介 rsync是linux系统下的数据镜像备份工具.使用快速增量备份工具Remote Sync可以远程同步,支持本地复制,或者与其他SSH.rsync主机同步. rsync特性 rsync ...
- CentOS 7 rsync+inotify实现实时同步
测试环境如下: inotify-slave IP : 172.16.0.222 inotify-master IP : 172.16.0.233 对两台机的要求: 安装依赖包gcc: yum inst ...
- centos 配置rsync+inotify数据实时同步2
一.Rsync服务简介 1. 什么是Rsync 它是一个远程数据同步工具,它在同步文件的同时,可通过LAN/WAN快速同步多台主机间的文件.Rsync使用所谓的“rsync算法”来使本地和远程两个主机 ...
- centos 配置rsync+inotify数据实时同步
何为rsync? 定义: rsync是一个开源的快速备份工具,可以在不同主机之间镜像同步整个目录树,支持增量备份,保持链接和权限,非常适用于异地备份 何为源端和发起端? 在远程同步过程中,负责发起rs ...
- rsync+inotify实现实时同步案例
转自:http://chocolee.blog.51cto.com/8158455/1400596 随着应用系统规模的不断扩大,对数据的安全性和可靠性也提出的更好的要求,rsync在高端业务系统中也逐 ...
随机推荐
- react.js 父子组件数据绑定实时通讯
import React,{Component} from 'react' import ReactDOM from 'react-dom' class ChildCounter extends Co ...
- 在RedHat 5下安装Oracle 10g详解(转)
在RedHat 5下安装Oracle 10g详解(转) Posted on 2012-09-14 13:26 疯狂 阅读(5075) 评论(0) 编辑 收藏 所属分类: database .uni ...
- bitcms-比特内容管理系统 3.1版源码发布
bitcms比特内容管理系统,经过几个版本的更新和客户的使用已经基本上完善了.下面主要介绍下他的运行环境和功能. 一.运行环境:windows server+IIS bitcms采用Entity Fr ...
- BZOJ1700: [Usaco2007 Jan]Problem Solving 解题
每月m<=1000块钱,有n<=300道题,要按顺序做,每月做题要花钱,花钱要第一个月预付下个月立即再付一次,给出预付和再付求最少几个月做完题,第一个月不做. 神奇的DP..竟没想出来.. ...
- Codeforces 658B Bear and Displayed Friends【set】
题目链接: http://codeforces.com/contest/658/problem/B 题意: 给定元素编号及亲密度,每次插入一个元素,并按亲密度从大到小排序.给定若干操作,回答每次询问的 ...
- Codeforces 653D Delivery Bears【二分+网络流】
题目链接: http://codeforces.com/problemset/problem/653/D 题意: x个熊拿着相同重量的物品,从1号结点沿着路走到N号结点,结点之间有边相连,保证可以从1 ...
- GOF 23种设计模式目录
经典的gof 23种设计模式,目录大纲查看. 1. Singleton(单例模式) 保证一个类只有一个实例,并提供访问它的全局访问点. 2. Abstract Factory(抽象工厂模式) 提供一个 ...
- Piggy-Bank--hdu1114(完全背包)
http://acm.hdu.edu.cn/showproblem.php?pid=1114 Problem Description Before ACM can do anything, a bud ...
- 在d盘中创建一个文件夹 在文件夹里创建三个txt文本
import java.io.File; import java.io.IOException; public class FileDemo { public static void main(Str ...
- java 读取数据库数据转化输出XML输出在jsp页面
因为老师实验报告要求,搭建服务端解析XML 下面代码实现转化XML格式也是在网上找的转化代码 输出在jsp页面以便于客户端解析是自己写的 一个类就解决了Test package tests; //三只 ...