生产环境和QA环境中的数据库服务器操作系统为centos,需要使用Rsync+Inotify模式来将生产环境中的mysql备份文件传输到QA环境中,然后在QA环境中进行还原。
实现目标如下所示:
源服务器:10.228.1.145
目标服务器:192.168.106.66
目的:在源服务器上将mysql定期备份的文件实时同步到目标服务器目录下进行还原

Rsync+Inotify 实现原理:
源服务器和目标服务器都需要安装Rsync,Inotify只在源服务器上安装
源机器上的Inotify实时监控主机上的某个目录,如果发现目录中有增删改的操作就把相应文件使用Rsync推送到目标端服务器上。

具体安装步骤如下:
1)Rsync安装配置
Rsync软件linux系统自带,只需要配置即可。
检查rsync是否已安装:

#rpm –qa | grep rsync
  • 目标服务器192.168.106.66 rsync安装配置

1、在/usr/local目录下新建mysqlbak目录。
2、在/etc目录下新建rsyncd.conf文件,内容如下:

uid = root
gid = root
use chroot = no
max connections = 5
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
log file = /var/log/rsyncd.log
[bak]
path=/usr/local/mysqlbak
comment = update
ignore errors
read only = no
list = no
auth users = root
uid = root
gid = root
secrets file = /etc/rsyncd.secrets

3、在/etc目录下新建rsyncd.secrets文件,内容如下:

root:gta@2014  #此处为操作系统账号密码

4、修改/etc/rsyncd.secrets权限:

#chmod 600 /etc/rsyncd.secrets

至此目标服务器192.168.106.66 rsync安装配置完成
启动rsync:

rsync --daemon --config=/etc/rsyncd.conf

查看rsync端口是否已开启:

netstat -nutlp | grep :873
  • 源服务器10.228.1.145 rsync安装配置

源服务器配置rsync非常简单:
1、在/etc目录下新建rsyncd.secrets文件,内容如下:

gta@2014 #此处为操作系统密码

2、修改/etc/rsyncd.secrets权限:

#chmod 600 /etc/rsyncd.secrets

至此源服务器10.228.1.145 rsync安装配置完成

2)Inotify安装配置
Inotify只需要在源服务器10.228.1.145上安装配置
1、在安装之前需要查看服务器内核是否支持inotify:

ll /proc/sys/fs/inotify   #列出文件目录,出现下面的内容,说明服务器内核支持inotify
-rw-r--r-- 1 root root 0 Mar  7 02:17 max_queued_events
-rw-r--r-- 1 root root 0 Mar  7 02:17 max_user_instances
-rw-r--r-- 1 root root 0 Mar  7 02:17 max_user_watches

备注:Linux下支持inotify的内核最小为2.6.13,可以输入命令:uname -a查看内核
2、安装inotify-tools

yum install make  gcc gcc-c++  #安装编译工具

上传inotify-tools-3.14.tar.gz到/usr/local/目录下

cd /usr/local/
tar zxvf inotify-tools-3.14.tar.gz  #解压
cd inotify-tools-3.14 #进入解压目录
./configure  #配置
make  #编译
make install  #安装

3、创建配置文件
在/usr/local目录下新建mysqlbak目录
在/usr/local目录下新建inotify.sh文件,输入以下内容:

#!/bin/bashsrc=/usr/local/mysqlbakdes=bakhostip=10.222.11.43cd ${src}/usr/local/bin/inotifywait -mrq  --timefmt '%d/%m/%y %H:%M' --format '%e %w%f %T' -e create ./ | while read filedoINO_EVENT=$(echo $file | awk '{print $1}')INO_FILE=$(echo $file | awk '{print $2}')echo "-------------------------------$(date)------------------------------------"echo $fileif [[ $INO_EVENT =~ 'CREATE' ]] || [[ $INO_EVENT =~ 'MODIFY' ]] ||[[ $INO_EVENT =~ 'CLOSE_WRITE' ]] || [[ $INO_EVENT =~ 'MOVED_TO' ]] ||[[ $INO_EVENT =~ 'ATTRIB' ]]thenecho $INO_EVENTrsync -avzcR  --password-file=/etc/rsyncd.secrets $(dirname ${INO_FILE})  root@$hostip::$desfiif [[ $INO_EVENT =~ 'DELETE' ]] || [[ $INO_EVENT =~ 'MOVED_FROM' ]]thenecho $INO_EVENTrsync -avzR  --delete  --password-file=/etc/rsyncd.secrets $(dirname ${INO_FILE})  root@$hostip::$desfidone

脚本创建完成后,即可启动脚本:

nohup sh inotify.sh &

此时在/usr/local/mysqlbak目录中生成的文件即可传到到目标端中目录中。

更多详细的功能可以参考:https://www.cnblogs.com/f-ck-need-u/p/7220009.html

转载于:https://www.cnblogs.com/blogjun/articles/8249906.html

Rsync+Inotify操作文档相关推荐

  1. 如何修改DynEd的学生记录服务器,DynEd教师管理端操作文档..docx

    DynEd教师管理端操作文档. DynEd教师管理端Records Manager操作文档DynEd教学理念语言是一种技能传统的英语教学太过注重读写,而疏于听说能力的发展.学生花费了大量的时间来背单词 ...

  2. mallplus多商户商城全流程 操作文档

    下载地址 https://gitee.com/catshen/zscat_sw 用户端 http://www.yjlive.cn:8082/#/ 商户端 http://www.yjlive.cn:80 ...

  3. 狮子鱼社区团购支付时出现appid和mch-id不匹配的解决方法及狮子鱼官方操作文档

    解决方法:这点需要到微信小程序后台设置:微信支付–关联更多商户号:如下图所示: 此处绑定商户号需要先将该小程序认证,认证有两种方法,一种是直接给该小程序交300元给微信官方:如果已经有公众号已经认证过 ...

  4. 赫拉(hera)分布式任务调度系统之操作文档

    文章目录 前言 操作文档 登录和注册 用户 用户组 总结 首页 机器组监控 系统管理 用户管理 用户组 用户 总结 监控管理 机器组管理&worker管理 任务管理 任务详情 任务依赖 上游任 ...

  5. ElasticSearch入门简介、安装ES(安装Kibana和IK分词器)使用 Postman连接ES进行测、ESRestAPI(操作索引CRUD操作文档CRUD)、练习

    要理解倒排索引 要能够使用DSL命令操作索引库 要能够使用DSL命令操作文档 要能够使用RestAPI操作索引库.文档 一.ES简介 理解倒排索引的概念和作用 理解es和MySql的区别和使用场景 1 ...

  6. kvm介绍与操作文档

    -- 虚拟化 KVM  (kernel-based virtual machine) xen   kvm    vmare esx          openVZ     Oracle VM Virt ...

  7. Word2010开发——操作文档

    参考: http://blog.csdn.net/akipeng/article/details/6534375 http://www.haogongju.net/art/19029 首先建立一个Wo ...

  8. aspose.words for java操作文档doc,设置一级二级三级标题以及段落表格等详情

    实现将aspose.words的相关组件jar包 以下是我自己编辑整理的工具类,欢迎交流 package com;import java.io.InputStream;import org.slf4j ...

  9. WinForm之创建word并操作文档

    private void button1_Click(object sender, EventArgs e){if (textBox1.Text == "" || textBox2 ...

最新文章

  1. css3 使用SVG做0.5px 的边框细线
  2. 机器学习:一步步教你理解反向传播方法
  3. 2021年世界科技进展100项
  4. [收藏]用CSS构建iframe效果
  5. linux系统日志_Linux系统学习系列——Linux系统日志管 理(下 )
  6. Android 8.0学习(25)---系统的应用图标适配
  7. MySQL截取SUBSTRING
  8. 不通用版(从SVN取版本,通过MAVEN生成JAVA包,通过SALTSTACK传送到远程服务器并自动重启TOMCAT服务)PYTHON代码...
  9. 人工智能翻译能否替代人工翻译,人工智能翻译何去何从
  10. 关于极限编程简单介绍
  11. Brocade 光纤交换机配置命令
  12. c++实验题:设计两个酒店管理员客房管理的类:一个是Person类,要求储存房号、客户姓名和身份证号的信息;另一个类是Client类,要求新增客户的订房、退房和消费金额等信息,并给出相关测试算法。
  13. 寒假集训_专题三题解_C - 六度分离
  14. 数据库防火墙:数据库防火墙商业化的前提条件
  15. 模拟卷Leetcode【普通】198. 打家劫舍
  16. 苏州微软面试--机器学习自然语言处理
  17. HTML表格简单的创建与制作
  18. 超市收银系统测试报告
  19. Python:学习成绩管理系统
  20. hacking 麦步手表之(2)命令行编译工程

热门文章

  1. php 采集不到内容_Thinkphp5与QueryList,也可以实现采集(爬虫)页面功能
  2. dns服务期搭建使用_自己搭建dns服务器
  3. 模数转换实验中断方式c语言,DSP实验报告--模拟信号的AD+FFT变换
  4. 西门子mag6000接线_电磁流量计MAG5000或MAG6000,通过脉冲输出累积流量,脉冲输出如何接线,如何设置参数?...
  5. zc706开发板的linux移植,Zynq—Linux移植学习笔记(十)
  6. form表单属性名相同java_java – 将表单字段注入具有相同属性名称的多个bean中
  7. 湖南科技大学计算机男女比例,湖师大文学院新生男女比例1:9 成了“女儿国”...
  8. ImportError: No module named six
  9. 大数据学习笔记:ZooKeeper练习
  10. 波利亚名著《怎样解题》笔记:四步解题法