在高并发网站架构中,MySQL数据库主从同步是不可或缺的,不过经常会发生由于网络原因或者操作错误,MySQL主从经常会出现不同步的情况,那么如何监控MySQL主从同步,也变成检测网站正常运行的重要环节。
MySQL同步功能由3个线程(master上1个,slave上2个)来实现,简单的说就是:master发送日志一个,slave接收日志一个,slave运行日志一个。
首先,我们解释一下 show slave status 中重要的几个参数:
那么如何监控从服务器是否正常运行呢?
1、创建监控MYSQL的账号
2、写一个监控脚本
这个脚本主要用于获取MYSQL主从同步信息;
我们先执行一个命令
我们在输出的信息中选择
这两项来监控,我测试了一下,当操作的数据出现异常的时候,Slave_SQL_Running就会变成No,当执行slave stop的时候,两个都会变成No;
脚本内容如下
我只写了一条命令,这里详细说明一下它的意思;
先用zabbix这个用户来获取slave的所有状态,然后grep出这两个状态,然后再输出第二列,最后查看有几个Yes状态的,正常情况下有两个Yes状态。
3、在zabbixagent里面添加监控项
文件的最后添加如下一行
等号后面的字符串中,逗号前面是Key,后面是执行的脚本(脚本不要忘了执行权限)
添加好之后,就重启agent程序
4、Server端添加监控项
这里的192.168.0.34 是我的agent的IP,如果主从复制正常,就会返回2 (代表两个状态都是Yes),现在就说明Server已经可以从agent获取状态了,现在在管理界面中先添加监控项:
配置--模板
先创建一个模板,这个模板的主要功能是用于监视MYSQL主从复制的状态;
添加触发器
当返回的值小于2时,说明只存在1个YES或0个YES,这时候说明MYSQL主从同步出现异常,即产生报警;
获取最新数据
在这里可以看到,已经获取了最新的监控数据,说明监控添加成功;