innotify主要功能:

他是内核用于通知用户控件程序文件系统变化的机制。

也就是说,当服务器发生了任何的改动,内核都会知道并通知用户。

rssync(做同步的)+innotify做到的就是实时的同步。

首先,我们需要明白的rsync的工作机制,常用的工作模式有俩种:

1,rsync客户端向服务器端推送文件。eg:

rsync -avz --progress /opt/ yangshuai@192.168.10.152::backup1 --password-file=/etc/rsyncd.secrets1

opt:客户端被推送文件所在的目录。

yangshuai@192.168.10.152::backup1   对端服务器的用户和IP,加上模块

/etc/rsyncd.secrets1:本机的密码文件,只有密码。

2,rsync客户端从服务器端下载文件。

rsync -vzrtopg  --password-file=/etc/rsyncd.secrets yangshuai@192.168.10.252::backup /opt

--password-file=/etc/rsyncd.secrets:本机的密码文件,只有密码.

yangshuai@192.168.10.252::backup   对端服务器的用户和IP,加上模块

opt:   想要把从服务器端下载的文件存放的目录。

要想利用rsync+innotify做到实时同步,我们可以用到的是rsync客户端向服务器端传送文件。

客户端需要做的是安装rsync,并安装innotity模块。

安装rsync:

yum -y install rsync

无需输入密码访问  echo "123456">>/etc/rsyncd.secrets

安装innotity模块并写监控脚本:

将压缩包上传到客户端

解压:tar zvxf inotify-tools-3.13.tar.gz

编译安装: cd  inotify-tools-3.13

./configure --prefix=/usr/local/inotify

make && make install

编写监控脚本:

vi  rsync.sh

#!/bin/bash

src=/opt/

des=backup1

ip=192.168.10.152

/usr/local/inotify/bin/inotifywait -mrq --timefmt '%d/%m/%y/%H:%M' --format '%T%w%f' -e modify,delete,create,attrib $src | while read file

do

rsync -vzrtopg --delete --progress $src yangshuai@$ip::$des --password-file=/etc/rsyncd.secrets1 &&

echo "$src has been resynced"

done

执行监控脚本,并在后台执行

sh  rsync.sh  &

服务器端做的配置:

安装rsync,并编写配置文件:

yum -y install rsync

vi /etc/rsyncd.conf

pid file = /var/run/rsyncd.pid

port = 873

address = 192.168.10.152    #主机的地址

uid = root

gid = root

use chroot = yes

read only = no

write only = no

hosts allow = *   #备份主机的地址

hosts deny = *

max connections = 10

timeout = 300

log file = /var/log/rsyncd.log

transfer logging = yes

log format = %t %a %m %f %b

[backup1]

path=/opt/                    #被客户端推送的时候,是存放路径:被客户端下载的时候,是下载路径。

list = yes

ignore errors = yes

auth users = yangshuai                                    #连接用户的名字

secrets file=/etc/rsyncd.secrets

编写密码文件并配置权限:

vi  /etc/rsyncd.secrets

yangshuai:123456

chmod 600 /etc/rsyncd.secrets

启动服务:

rsync  --daemon

现在整个rsync服务器就已经搭建好了,并且能做到实时同步。

直接在客户端做测试就好了

日常笔记,有问题的话请联系我531197592@qq.com

rsync+innotify做到同步式更新的更多相关文章

  1. Rsync+lsync实现触发式实时同步

    使用rsync+lsync实现触发式实时同步 服务器信息 centos6.5 主:192.168.5.4 搭建lsync 从:192.168.5.3 搭建rsync 1.1 从服务器设置 # yum ...

  2. 分布式系统中一些主要的副本更新策略——Dynamo/Cassandra/Riak同时采取了主从式更新的同步+异步类型,以及任意节点更新的策略。

    分布式系统中一些主要的副本更新策略. 1.同时更新 类型A:没有任何协议,可能出现多个节点执行顺序交叉导致数据不一致情况. 类型B:通过一致性协议唯一确定不同更新操作的执行顺序,从而保证数据一致性 2 ...

  3. rsync+inotify 实现资源服务器的同步目录下的文件变化时,备份服务器的同步目录更新,以资源服务器为准,去同步其他客户端

    测试环境: 资源服务器(主服务器):192.168.200.95 备份服务器(客户端):192.168.200.89 同步目录:/etc/test 同步时使用的用户名hadoop密码12345 实验目 ...

  4. 2-3-2 rsync+inotify备份同步数据

    RSYNC = Remote Sync 远程同步 高效,一定要结合shell 官网:https://rsync.samba.org Author: Andrew Tridgell, Wayne Dav ...

  5. (转)rsync+inotify实时同步

    原文:http://lxw66.blog.51cto.com/5547576/1331048 声明:rsync inotify 需要逆向思考,当只做rsync不实时同步时,我们一般是从rsync服务端 ...

  6. linux服务器之间的文件同步;rsync+inotifywait;同步多个目录

    1.双向同步:unison+inotify 2.单向同步:rsync+inotify python版的pyinotify 本文介绍第二种方法: 1.Inotify 是一个 Linux特性,它监控文件系 ...

  7. inotify+rsync文件实时同步

    原文转自http://dl528888.blog.51cto.com/2382721/771533/ 之前做了“ssh信任与scp自动传输脚本”的技术文档,此方案是作为公司里备份的方法,但在实际的运行 ...

  8. RSync实现文件备份同步

    [rsync实现网站的备份,文件的同步,不同系统的文件的同步,如果是windows的话,需要windows版本cwrsync] 一.什么是rsync rsync,remote synchronize顾 ...

  9. 【转】CentOS5.6下配置rsync内网同步数据到外网

    [转]CentOS5.6下配置rsync内网同步数据到外网 本文转自:http://www.linuxidc.com/Linux/2012-06/64070.htm 一.需求 卫士那边有一个需求,就是 ...

随机推荐

  1. 学习笔记-JS公开课三

    DOM技术概述 DOM : DocumentObject Model 将HTML标记型文档,封装成对象,提供更多的属性和行为 DOM的三级模型 第一级:将标记型文档,封装成对象,提供更多的属性和行为 ...

  2. Android的图片,字符串,demin,color,以及Array,boolean,Integer资源的使用-android学习之旅(五十四)

    总体介绍 颜色值的定义 定义字符串,颜色,尺寸资源 字符串 颜色资源 尺寸资源 使用字符串,颜色,尺寸资源 boolean的定义与使用 整形常量的定义与使用 数组资源的定义与使用 图片资源的使用

  3. iOS中 超简单抽屉效果(MMDrawerController)的实现

    ios开发中,展示类应用通常要用到抽屉效果,由于项目需要,本人找到一个demo,缩减掉一些不常用的功能,整理出一个较短的实例. 首先需要给工程添加第三方类库 MMDrawerController: 这 ...

  4. (七十一)关于UITableView退出崩溃的问题和滚动到底部的方法

    [TableView退出崩溃的问题] 最近在使用TableView时偶然发现在TableView中数据较多时,如果在滚动过程中退出TableView到上一界面,会引起程序的崩溃,经过网上查阅和思考我发 ...

  5. 判断无向图是否有环路的方法 -并查集 -BFS

    可以利用并查集或者带颜色标记的BFS(来自算法导论)判断. 首先介绍第一种,用并查集来判断: 首先初始化所有元素的根为-1,-1代表根节点,接下来对于图中的每一条边(v1,v2)都并入集合,并入的方式 ...

  6. MySQL语句高效写法整理

    优先使用INNER JOIN 多表关联查询,扫描的行尽量少         关联的时候下条件减少扫描的行数 SELECT     ... FROM     ad_ad_summary_for_pos_ ...

  7. Java Web 高性能开发,第 1 部分: 前端的高性能

    Web 发展的速度让许多人叹为观止,层出不穷的组件.技术,只需要合理的组合.恰当的设置,就可以让 Web 程序性能不断飞跃.所有 Web 的思想都是通用的,它们也可以运用到 Java Web.这一系列 ...

  8. iOS中 UITableViewRowAction tableViewcell编辑状态下的功能 UI技术分享

    * tableView:editActionsForRowAtIndexPath: // 设置滑动删除时显示多个按钮 * UITableViewRowAction // 通过此类创建按钮 * 1. 我 ...

  9. 使用批处理文件(*.bat)同时打多个cmd窗口

    使用批处理文件(*.bat)同时打多个cmd窗口 最近在研究zookeeper,在本地建了几个目录,发现频繁的去各个目录启动zkServer.cmd十分繁琐,于是乎google,才有了下文: 使用批处 ...

  10. 多线程爬虫Miner

    多线程爬虫Miner 需要配置项:1.URL包含关键字.2.存储方式:DB-数据库存储;FILE-文件存储.3.爬取页面最大深度.4.下载页面线程数.5.分析页面线程数.6.存储线程数. ------ ...