rsync+innotify做到同步式更新
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做到同步式更新的更多相关文章
- Rsync+lsync实现触发式实时同步
使用rsync+lsync实现触发式实时同步 服务器信息 centos6.5 主:192.168.5.4 搭建lsync 从:192.168.5.3 搭建rsync 1.1 从服务器设置 # yum ...
- 分布式系统中一些主要的副本更新策略——Dynamo/Cassandra/Riak同时采取了主从式更新的同步+异步类型,以及任意节点更新的策略。
分布式系统中一些主要的副本更新策略. 1.同时更新 类型A:没有任何协议,可能出现多个节点执行顺序交叉导致数据不一致情况. 类型B:通过一致性协议唯一确定不同更新操作的执行顺序,从而保证数据一致性 2 ...
- rsync+inotify 实现资源服务器的同步目录下的文件变化时,备份服务器的同步目录更新,以资源服务器为准,去同步其他客户端
测试环境: 资源服务器(主服务器):192.168.200.95 备份服务器(客户端):192.168.200.89 同步目录:/etc/test 同步时使用的用户名hadoop密码12345 实验目 ...
- 2-3-2 rsync+inotify备份同步数据
RSYNC = Remote Sync 远程同步 高效,一定要结合shell 官网:https://rsync.samba.org Author: Andrew Tridgell, Wayne Dav ...
- (转)rsync+inotify实时同步
原文:http://lxw66.blog.51cto.com/5547576/1331048 声明:rsync inotify 需要逆向思考,当只做rsync不实时同步时,我们一般是从rsync服务端 ...
- linux服务器之间的文件同步;rsync+inotifywait;同步多个目录
1.双向同步:unison+inotify 2.单向同步:rsync+inotify python版的pyinotify 本文介绍第二种方法: 1.Inotify 是一个 Linux特性,它监控文件系 ...
- inotify+rsync文件实时同步
原文转自http://dl528888.blog.51cto.com/2382721/771533/ 之前做了“ssh信任与scp自动传输脚本”的技术文档,此方案是作为公司里备份的方法,但在实际的运行 ...
- RSync实现文件备份同步
[rsync实现网站的备份,文件的同步,不同系统的文件的同步,如果是windows的话,需要windows版本cwrsync] 一.什么是rsync rsync,remote synchronize顾 ...
- 【转】CentOS5.6下配置rsync内网同步数据到外网
[转]CentOS5.6下配置rsync内网同步数据到外网 本文转自:http://www.linuxidc.com/Linux/2012-06/64070.htm 一.需求 卫士那边有一个需求,就是 ...
随机推荐
- 【unix网络编程第三版】阅读笔记(五):I/O复用:select和poll函数
本博文主要针对UNP一书中的第六章内容来聊聊I/O复用技术以及其在网络编程中的实现 1. I/O复用技术 I/O多路复用是指内核一旦发现进程指定的一个或者多个I/O条件准备就绪,它就通知该进程.I/O ...
- android:getSlotFromBufferLocked: unknown buffer: 0xf3d544c0
欢迎关注公众号,每天推送Android技术文章,二维码如下:(可扫描) 今天运行一个小程序,退出的时候竟然打出一条错误log日志.一时慌乱,在国内网站也没找到合适的答复.通过查看国外的网站终于查到了原 ...
- Unity UGUI基础之Button
UGUI Button,可以说是真正的使用最广泛.功能最全面.几乎涵盖任何模块无所不用无所不能的组件,掌握了它的灵巧使用,你就几乎掌握了大半个UGUI! 一.Button组件: Interactabl ...
- EXCEPTION与ERROR的区别
EXCEPTION与ERROR的区别
- VB.NET版机房收费系统---组合查询
查询的意思就是查找,寻找,指在某一个或几个地方找出自己所要的信息,假如我想搜索一下我自己写的博客,名字叫做初雪之恋,我在百度的搜索框中输入丁国华三个字,会有怎样的惊喜等着我? 啊哦,这个信息并不是我想 ...
- 关于Eclipse创建Android项目时,会多出一个appcompat_v7的问题
问题描述: 使用eclipse创建一个Android项目时,发现project列表中会多创建出一个appcompat_v7项目,再创建一个Android项目时,又会再多出一个appcompat_ ...
- Android开发技巧——TextView加载HTML的图片及代码显示问题
前几天在做一个Gradle用户指南的应用程序,使用的是TextView来加载HTML内容(至于为什么不用WebView,我也没有认真使用并比较过,也许以后会换吧),其中遇见了一些纠结的问题,所幸主要的 ...
- 内连接、左外连接、右外连接、全外连接、交叉连接(CROSS JOIN)-----小知识解决大数据攻略
早就听说了内连接与外连接,以前视图中使用过.这次自考也学习了,只是简单理解,现在深入探究学习(由于上篇博客的出现)与实践: 概念 关键字: 左右连接 数据表的连接有: 1.内连接(自然连接): 只有两 ...
- 二叉树的最大深度算法面试题-leetcode学习之旅(3)
标题 Maximum Depth of Binary Tree 描述 The maximum depth is the number of nodes along the longest path f ...
- 网络小白之WAN与LAN的区别
剑指Offer--网络小白之WAN与LAN的区别 基本作用 wan接口是外网接口,是用来连接互联网或局域网等外部网络的. lan接口是内网接口,是用来连接计算机终端或其他路由器等终端设备的. 举例 w ...