centos8安装sersync为rsync实现实时同步
一,查看本地centos的版本:
[root@localhost lib]# cat /etc/redhat-release
CentOS Linux release 8.1.1911 (Core)
说明:刘宏缔的架构森林是一个专注架构的博客,地址:https://www.cnblogs.com/architectforest
对应的源码可以访问这里获取: https://github.com/liuhongdi/
说明:作者:刘宏缔 邮箱: 371125307@qq.com
二,查看内核是否支持inotify
[root@localhost nfs]# ll /proc/sys/fs/inotify/
总用量 0
-rw-r--r-- 1 root root 0 2月 24 15:01 max_queued_events
-rw-r--r-- 1 root root 0 2月 24 15:01 max_user_instances
-rw-r--r-- 1 root root 0 2月 24 13:20 max_user_watches
说明:看到列出的三个文件,说明系统内核支持inotify
说明:sersync是基于inotify的,所以需要这个功能模块的支持
三,配置inotify参数,避免因限制导致出错
查看inotify相关的三个值:
分别为:队列中event的长度,用户可监控数量的多少,用户可使用的实例数量
[root@localhost nfs]# sysctl -a | grep max_queued_events
fs.inotify.max_queued_events = 16384
[root@localhost nfs]# sysctl -a | grep max_user_watches
fs.inotify.max_user_watches = 8192
[root@localhost nfs]# sysctl -a | grep max_user_instances
fs.inotify.max_user_instances = 128
修改:
[root@localhost source]# sysctl -w fs.inotify.max_queued_events="327679"
fs.inotify.max_queued_events = 327679
[root@localhost source]# sysctl -w fs.inotify.max_user_watches="50000000"
fs.inotify.max_user_watches = 50000000
[root@localhost source]# sysctl -w fs.inotify.max_user_instances="65535"
fs.inotify.max_user_instances = 65535
[root@localhost source]# sysctl -p
四,下载安装sersync
1,下载地址
说明:官方地址:
https://sersync.googlecode.com/files/sersync2.5.4_64bit_binary_stable_final.tar.gz
在墙外打不开,大家可以访问下面github上面的地址:
https://github.com/wsgzao/sersync
2,下载及解压:
[root@localhost source]# wget https://codeload.github.com/wsgzao/sersync/zip/master
[root@localhost source]# mv master master.zip
[root@localhost source]# unzip master.zip
3,安装到soft目录
[root@localhost source]# cd sersync-master/
[root@localhost sersync-master]# ls
inotify-tools-3.14.tar.gz README.md rsync-3.1.1.tar.gz sersync2.5.4_64bit_binary_stable_final.tar.gz
[root@localhost sersync-master]# tar -zxvf sersync2.5.4_64bit_binary_stable_final.tar.gz
[root@localhost sersync-master]# mv GNU-Linux-x86/ /usr/local/soft/sersync2
五,查看sersync的帮助信息
[root@localhost sersync-master]# /usr/local/soft/sersync2/sersync2 -help
六,sersync的参数说明:
参数-d:启用守护进程模式
参数-r:在监控前,将监控目录与远程主机用rsync命令推送一遍
参数-n: 指定开启守护线程的数量,默认为10个
参数-o:指定配置文件,默认使用confxml.xml文件
七,sersync的配置:
1,inotify项的配置建议:说明:是使用inotify监控的类型:
<inotify>
<delete start="true"/>
<createFolder start="true"/>
<createFile start="true"/>
<closeWrite start="true"/>
<moveFrom start="true"/>
<moveTo start="true"/>
<attrib start="false"/>
<modify start="true"/>
</inotify>
2,localpath:
<localpath watch="/data/nfs/source">
<remote ip="127.0.0.1" name="wwwroot"/>
<!--<remote ip="192.168.8.39" name="tongbu"/>-->
<!--<remote ip="192.168.8.40" name="tongbu"/>-->
</localpath>
说明:
/data/nfs/source是本地要监控的目录
remote 对应服务的ip和name
3,rsync的配置
<rsync>
<commonParams params="-artuz"/>
<auth start="true" users="pusher" passwordfile="/data/rsync/conf/client.pass"/>
<userDefinedPort start="false" port="874"/><!-- port=874 -->
<timeout start="false" time="100"/><!-- timeout=100 -->
<ssh start="false"/>
</rsync>
4,说明:其他的设置项不必改动
八,运行sersync
[root@localhost liuhongdi]# /usr/local/soft/sersync2/sersync2 -r -d -o /usr/local/soft/sersync2/confxml.xml
九,关于rsync服务的搭建:参见这一篇:
https://www.cnblogs.com/architectforest/p/12360875.html
十,sersync的日志位于何处?
[root@localhost liuhongdi]# more /tmp/rsync_fail_log.sh
#errno 2560
cd /data/nfs/source && rsync -artuz -R "./abc.txt" pusher@127.0.0.1::wwwroot --password-file=/data/rsync/conf/client.pass >/dev/null 2>&1
十一,测试本地两个目录的同步情况:
1, /data/nfs/source这个目录是sersync监控的目录
[root@localhost source]# pwd
/data/nfs/source
[root@localhost source]# vi rand.txt
[root@localhost source]# more rand.txt
rand
2,/data/nfs/dest 是rsync服务中wwwroot这个区域指定的目录
[root@localhost dest]# pwd
/data/nfs/dest
[root@localhost dest]# more rand.txt
rand
说明:在监控目录中增加文件后,rsync同步的目录中文件也立即出现,且内容相同
所以sersync很适合做文件备份
centos8安装sersync为rsync实现实时同步的更多相关文章
- 【转】inotify+rsync实现实时同步
[转]inotify+rsync实现实时同步 1.1 什么是实时同步:如何实现实时同步 要利用监控服务(inotify),监控同步数据服务器目录中信息的变化 发现目录中数据产生变化,就利用rsync服 ...
- rsync nfs 实时同步,结合实战
目录 rsync nfs 实时同步,实战 一.部署rsync服务端(backup) 二.部署rsync客户端(nfs,web01) 三.部署web代码(web01) 四.NFS服务端部署(nfs) 五 ...
- rsync+inotify实时同步环境部署记录
随着应用系统规模的不断扩大,对数据的安全性和可靠性也提出的更好的要求,rsync在高端业务系统中也逐渐暴露出了很多不足.首先,rsync在同步数据时,需要扫描所有文件后进行比对,进行差量传输.如果文件 ...
- rsync+inotify实时同步方案
rsync+inotify实时同步,inotify可以实时监控本地文件或目录变化,当检测到本地文件变化,执行rsync同步命令,将变化的文件同步到其他服务器节点. 1.配置环境 3.在服务节点1.服务 ...
- CentOS6.5实现rsync+inotify实时同步
参考博文: 参考1:CentOS6.5实现rsync+inotify实时同步 参考2:inotify-tools+rsync实时同步文件安装和配置 CentOS 6.3下rsync服务器的安装与配置 ...
- Rsync同步、Rsync+Lsync实时同步
Rsync同步.Rsync+Lsync实时同步 原创博文http://www.cnblogs.com/elvi/p/7658049.html #!/bin/sh #Myde by Elven @ #c ...
- 配置rsync+inotify实时同步
与上一篇同步做 配置rsync+inotify实时同步 1:调整inotify内核参数 在linux内核中,默认的inotify机制提供三个调控参数:max_queue_events.max_user ...
- (转)rsync+inotify实时同步
原文:http://lxw66.blog.51cto.com/5547576/1331048 声明:rsync inotify 需要逆向思考,当只做rsync不实时同步时,我们一般是从rsync服务端 ...
- linux设置rsync+inotify实时同步文件
linux设置rsync+inotify实时同步文件 应用场景: 同步接收方:test01 接收目录:/opt/software/test/a/ 同步发起方:test02 同步目录:/opt/so ...
随机推荐
- C enum(枚举)
C enum(枚举) 枚举是 C 语言中的一种基本数据类型,它可以让数据更简洁,更易读. 枚举语法定义格式为: enum 枚举名 {枚举元素1,枚举元素2,……}; 接下来我们举个例子,比如:一星期有 ...
- python之class Meta用法
Django model中的 class Meta 详解 通过一个内嵌类 "class Meta" 给你的 model 定义元数据, 类似下面这样: class Foo(mod ...
- 漏洞扫描工具acunetix破解安装步骤
Acunetix 12破解版安装教程 下载地址: 链接:https://pan.baidu.com/s/1jsKkrhOcx_O7ib7FQ6pidw 提取码:pwdj 1.下载软件压缩包文件,首先点 ...
- [Java核心技术]五-继承(枚举类)
####Java枚举类型(enum) 枚举类型都是继承了Enum类(是一个抽象类)的一个类,我们可以向enum类中添加方法和变量等.编译再反编译可以看到枚举类型对应的类的内容. 每个枚举常量都对应一个 ...
- 预科班D6
2020.09.14星期一 预科班D6 学习内容: 自习 发布小游戏 1.配置网络 #查看当前ip ifconfig #关闭NetworkManager systemctl stop NetworkM ...
- 关于java基础_方法的学习
方法: 方法就是把一堆需要反复执行的代码封装起来,如果项目需要调用这段代码时,直接调用方法名即可 方法相当于榨汁机, 材料:水果 产出物:果汁 参数(材料):进入方法的数据 返回值(产出物):就是方法 ...
- EAM资产管理系统应用趋势简述
EAM资产管理系统应用趋势简述 随着各种企业对资产管理需求的不断增长,EAM市场也正在持续升温,对于石油.化工.煤炭.钢铁等流程化企业及其他资产密集型企业来说,设备占用了企业大量的成本,如何降低设备维 ...
- MySQL必知必会(1-12章)
第一章:了解SQL 数据库基础:(概念) 数据库软件: DBMS(数据库管理系统) 数据库: 通过DBMS创建和操纵的容器: 保存有组织的数据的容器-->通常是一个文件或者一组文件: 表: 某种 ...
- Spring系列之aAOP AOP是什么?+xml方式实现aop+注解方式实现aop
Spring系列之aop aop是什么?+xml方式实现aop+注解方式实现aop 什么是AOP? AOP为Aspect Oriented Programming 的缩写,意识为面向切面的编程,是通过 ...
- Urule开源版系列5——RuleSetParser解析过程
接上期Urule开源版系列4--Core包核心接口之规则解析过程 之前源码到了Parser,这期详细解析下RuleSetParser的解析过程 1.主流程 特殊处理一个属性 循环处理元素 当元素名称是 ...