0

0

rsync+inotify-tools+ssh实现mysql-bin日志文件实时备份_MySQL

php中文网

php中文网

发布时间:2016-05-30 17:10:40

|

1434人浏览过

|

来源于php中文网

原创

1、环境:两台Centos计算机直连,其服务器A的IP地址为192.168.1.124124,服务器B的IP地址为192.168.1.121。

 

2、需求软件安装(ssh系统默认已经安装):

 

服务器A:

yum install rsync inotify-tools

 

服务器B:

yum install rsync

 

3、建立用户(备份执行用户)

建立用户:useradd rsync

设置密码:略

注意:两台服务器都需要建立用户(此处两天服务器建立了相同的用户,也可建立不同的用户)

 

4、建立ssh-key实现ssh自动连接

服务器A

 

建立公钥和私钥

[root@A ~]# su - rsync

[rsync@A ~]$ ssh-keygen -t rsa(全部使用默认值,一直按回车即可)

完成后,此时会在/home/rsync/.ssh下,生成一对“公钥和私钥”,如下所示

[rsync@A .ssh]# ll

total 12

-rw-------. 1 rsync rsync 1675 Oct 20 01:47 id_rsa

-rw-r--r--. 1 rsync rsync  393 Oct 20 01:47 id_rsa.pub

 

然后,如下命令,将id_rsa.pub负责到服务器B上。

scp /home/rsync/.ssh/id.rsa.pub [email protected]:/home/rsync/

 

服务器B:

建立ssh存储“公钥”的目录:

mkdir /home/rsync/.ssh

chmod 700 /home/rsync/.ssh

将服务器A上传递的公钥,mv到/home/rsync/.ssh。如下命令

mv /home/rsync/id_rsa.pub /home/rsync/.ssh/authorized_keys

chmod 600 /home/rsync/.ssh/authorized_keys

 

重启SSH服务

[root@A ~]# /etc/init.d/sshd restart

[root@B ~]# /etc/init.d/sshd restart

 

5、inotify_tools的使用

1、确定inotifywait的位置

2、inotifywait的常见使用方法

 

/usr/bin/inotifywait -mrq -e modify,delete,create,attrib

命令解释:

Dreamlike.art
Dreamlike.art

内置5种模型的AI图像生成器

下载

-m 是保持一直监听

-r 是递归查看目录

-q 是打印出事件

-e create,move,delete,modify,attrib 是指 “监听 创建 移动 删除 写入 权限” 事件

 

6、服务器A上创建实时监控备份脚本inotify.ssh

 

#!/bin/sh

SRC=/usr/local/mysql/binlog/

DST=[email protected]:/home/rsync1/test

/usr/bin/inotifywait -mrq -e modify,delete,create,attrib ${SRC} | while read D E F

do

      /usr/bin/rsync -ahqzt --delete $SRC $DST

done

 

命令解释:

SRC:监控的目录()

DST:备份的目录

while read D E F:inotifywait 命令产生三个返回值,分别是“日期,时间,文件” 这3个返回值会做为参数传给read,因此脚本中的“while read D E F” 写法细化了返回值。

 

rsync命令解释:

/usr/bin/rsync -ahqzt --delete $SRC $DST

-a 存档模式

-h 保存硬连接

-q 制止非错误信息

-z 压缩文件数据在传输

-t 维护修改时间

-delete 删除于多余文件

 

7、脚本的运行

 

服务器A:

 

修改执行权限:chmod +x inotify.sh

在rsync用户模式下运行该脚本(ssh-key是rsync用户建立的):

su - rsync

[rsync@A sbin]$ ./inotify_rsync.sh &   #在后台运行

 

此次在服务器A的/usr/local/mysql/binlog/#在该目录下,建立文件和目录,可以实时备份到目标位置

 

注意:

1、备份用户rsync有没有读取/usr/local/mysql/binlog/目录的权限,不然备份失败

2、建议修改mysql-bin的存储目录,如下所示

log-bin=/usr/local/mysql/binlog/mysql-bin           

#打开日志(主机需要打开),这个mysql-bin也可以自定义,这里也可以加上路径,如:/usr/local/mysql/binlog/mysql-bin  

相关专题

更多
虚拟号码教程汇总
虚拟号码教程汇总

本专题整合了虚拟号码接收验证码相关教程,阅读下面的文章了解更多详细操作。

29

2025.12.25

错误代码dns_probe_possible
错误代码dns_probe_possible

本专题整合了电脑无法打开网页显示错误代码dns_probe_possible解决方法,阅读专题下面的文章了解更多处理方案。

20

2025.12.25

网页undefined啥意思
网页undefined啥意思

本专题整合了undefined相关内容,阅读下面的文章了解更多详细内容。后续继续更新。

37

2025.12.25

word转换成ppt教程大全
word转换成ppt教程大全

本专题整合了word转换成ppt教程,阅读专题下面的文章了解更多详细操作。

6

2025.12.25

msvcp140.dll丢失相关教程
msvcp140.dll丢失相关教程

本专题整合了msvcp140.dll丢失相关解决方法,阅读专题下面的文章了解更多详细操作。

2

2025.12.25

笔记本电脑卡反应很慢处理方法汇总
笔记本电脑卡反应很慢处理方法汇总

本专题整合了笔记本电脑卡反应慢解决方法,阅读专题下面的文章了解更多详细内容。

6

2025.12.25

微信调黑色模式教程
微信调黑色模式教程

本专题整合了微信调黑色模式教程,阅读下面的文章了解更多详细内容。

5

2025.12.25

ps入门教程
ps入门教程

本专题整合了ps相关教程,阅读下面的文章了解更多详细内容。

4

2025.12.25

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

218

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Java 教程
Java 教程

共578课时 | 37.9万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 0.9万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号