温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Zabbix 检测Mysql数据库的主从同步

发布时间:2020-05-24 20:33:30 来源:网络 阅读:782 作者:大屁孩儿 栏目:数据库


Zabbix 检测Mysql数据库的主从同步


在高并发网站架构中,MySQL数据库主从同步是不可或缺的,不过经常会发生由于网络原因或者操作错误,MySQL主从经常会出现不同步的情况,那么如何监控MySQL主从同步,也变成检测网站正常运行的重要环节。

MySQL同步功能由3个线程(master上1个,slave上2个)来实现,简单的说就是:master发送日志一个,slave接收日志一个,slave运行日志一个。

Zabbix 检测Mysql数据库的主从同步

Slave_io_Running:yes

Slave_SQL_Running: yes

这两个同时为yes时,表示主从同步,有一个变为no,同步失败

我们需要写一个脚本,来检测这两个参数的状态

cat mysql-replication.sh

#!/bin/bash

mysql -uroot

-p***-e 'show slave status\G' |grep -E "Slave_IO_Running|Slave_SQL_Running"|awk '{print $2}'|grep -c Yes

测试脚本时 出现如下错误

Warning: Using a password on the command line interface can be insecure.
2

这时检测端接受的数据是 错误和数据   无法被检测端接受

可以在my.cnf 中 [mysqld] 增加mysql 和 password 我们还可以给数据库一个没有密码的账户

mysql -uroot -p密码

mysql> grant replication client on *.* to 'zabbix'@'localhost';

测试将脚本更改为

#!/bin/bash

mysql -uzabbix -e 'show slave status\G' |grep -E "Slave_IO_Running|Slave_SQL_Running"|awk '{print $2}'|grep -c Yes

测试脚本显示如下

2

当显示1或者0的时候即为同步出现了问题

  在zabbix agent里面添加监控项

vim /usr/local/zabbix-3.0.4/etc/zabbix_agentd.conf

UserParameter=mysql.replication,/usr/local/zabbix-3.0.4/bin/mysql-replication.sh

等号后面的字符串中,逗号前面是Key,后面是执行的脚本(脚本不要忘了执行权限)

重启zabbix agent

在zabbix server做测试 看是否可以接受到数据

[root@zabbix bin]# ./zabbix_get -s 192.168.2.44 -k "mysql.replication"
2
表示成功

在监控界面增加监控项和触发器

Zabbix 检测Mysql数据库的主从同步

    当返回的值小于2时,说明只存在1个YES或0个YES,这时候说明MYSQL主从同步出现异常,即产生报警;

Zabbix 检测Mysql数据库的主从同步

此时在从库中执行stop slave ;

Zabbix 检测Mysql数据库的主从同步

接收到邮件

Zabbix 检测Mysql数据库的主从同步

启动salve start slave

Zabbix 检测Mysql数据库的主从同步

收到回复邮件

Zabbix 检测Mysql数据库的主从同步


增加主从监控成功







向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI