Zabbix 检测Mysql数据库的主从同步 推荐
2016-12-13 11:32
330 查看
在高并发网站架构中,MySQL数据库主从同步是不可或缺的,不过经常会发生由于网络原因或者操作错误,MySQL主从经常会出现不同步的情况,那么如何监控MySQL主从同步,也变成检测网站正常运行的重要环节。
MySQL同步功能由3个线程(master上1个,slave上2个)来实现,简单的说就是:master发送日志一个,slave接收日志一个,slave运行日志一个。
首先,我们解释一下 show slave status 中重要的几个参数:
那么如何监控从服务器是否正常运行呢?
我们先执行一个命令
我们在输出的信息中选择
这两项来监控,我测试了一下,当操作的数据出现异常的时候,Slave_SQL_Running就会变成No,当执行slave stop的时候,两个都会变成No;
脚本内容如下
我只写了一条命令,这里详细说明一下它的意思;
先用zabbix这个用户来获取slave的所有状态,然后grep出这两个状态,然后再输出第二列,最后查看有几个Yes状态的,正常情况下有两个Yes状态。
等号后面的字符串中,逗号前面是Key,后面是执行的脚本(脚本不要忘了执行权限)
添加好之后,就重启agent程序
这里的192.168.0.34 是我的agent的IP,如果主从复制正常,就会返回2 (代表两个状态都是Yes),现在就说明Server已经可以从agent获取状态了,现在在管理界面中先添加监控项:
配置--模板
先创建一个模板,这个模板的主要功能是用于监视MYSQL主从复制的状态;
添加触发器
当返回的值小于2时,说明只存在1个YES或0个YES,这时候说明MYSQL主从同步出现异常,即产生报警;
获取最新数据
在这里可以看到,已经获取了最新的监控数据,说明监控添加成功;
MySQL同步功能由3个线程(master上1个,slave上2个)来实现,简单的说就是:master发送日志一个,slave接收日志一个,slave运行日志一个。
首先,我们解释一下 show slave status 中重要的几个参数:
Slave_IO_Running: I/O线程是否被启动并成功地连接到主服务器上。 Slave_SQL_Running: SQL线程是否被启动。 Seconds_Behind_Master:本字段是从属服务器“落后”多少的一个指示。当从属SQL线程正在运行时(处理更新),本字段为在主服务器上由此线程执行的最近的一个事件的时间标记开始,已经过的秒数。当此线程被从属服务器I/O线程赶上,并进入闲置状态,等待来自I/O线程的更多的事件时,本字段为零。总之,本字段测量从属服务器SQL线程和从属服务器I/O线程之间的时间差距,单位以秒计。
那么如何监控从服务器是否正常运行呢?
1、创建监控MYSQL的账号
mysql -uroot -p密码 mysql> grant replication client on *.* to 'zabbix'@'localhost';
2、写一个监控脚本
这个脚本主要用于获取MYSQL主从同步信息;我们先执行一个命令
mysql -u zabbix -e 'show slave status\G'
我们在输出的信息中选择
Slave_IO_Running: Yes Slave_SQL_Running: Yes
这两项来监控,我测试了一下,当操作的数据出现异常的时候,Slave_SQL_Running就会变成No,当执行slave stop的时候,两个都会变成No;
脚本内容如下
#!/bin/bash mysql -uzabbix -e 'show slave status\G' |grep -E "Slave_IO_Running|Slave_SQL_Running"|awk '{print $2}'|grep -c Yes
我只写了一条命令,这里详细说明一下它的意思;
先用zabbix这个用户来获取slave的所有状态,然后grep出这两个状态,然后再输出第二列,最后查看有几个Yes状态的,正常情况下有两个Yes状态。
3、在zabbix agent里面添加监控项
文件的最后添加如下一行UserParameter=mysql.replication,/home/zabbix/mysql-replication.sh
等号后面的字符串中,逗号前面是Key,后面是执行的脚本(脚本不要忘了执行权限)
添加好之后,就重启agent程序
4、Server端添加监控项
zabbix_get -s 192.168.0.34 -k "mysql.replication" 2
这里的192.168.0.34 是我的agent的IP,如果主从复制正常,就会返回2 (代表两个状态都是Yes),现在就说明Server已经可以从agent获取状态了,现在在管理界面中先添加监控项:
配置--模板
先创建一个模板,这个模板的主要功能是用于监视MYSQL主从复制的状态;
添加触发器
当返回的值小于2时,说明只存在1个YES或0个YES,这时候说明MYSQL主从同步出现异常,即产生报警;
获取最新数据
在这里可以看到,已经获取了最新的监控数据,说明监控添加成功;
相关文章推荐
- Zabbix 检测Mysql数据库的主从同步
- Zabbix检测Mysql数据库的主从同步
- Zabbix 检测Mysql数据库的主从同步
- Zabbix 检测Mysql数据库的主从同步
- 借助zabbix和mysql performance monitor模板实现mysql数据库的监控 推荐
- zabbix监控mysql数据库(推荐这种方式:zabbix通过mpm监控mysql的环境搭建)
- mysql数据库主从同步(非交互式)
- MySQLinnodb_monitor及死锁检测 推荐
- mysql数据库自动备份,并发送邮件通知 推荐
- MySQL数据库中删除重复记录的方法总结[推荐]
- Zabbix3.0 图像中文显示乱码之解决方案 推荐
- 机器学习练习(八)—— 异常检测与推荐
- [转]正则表达式在线检测工具推荐
- MySQL数据库服务器端核心参数详解和推荐配置(二)
- 推荐一个web在线的mysql数据库管理系统
- 使用Navicat定时备份mysql数据库和创建报表并邮件自动发送 推荐
- zabbix监控检测hbase的region一致性
- MySQL数据库表分区注意事项大全【推荐】
- 身份证编码合法性检测(基于XML数据) 推荐
- sudo bug导致的zabbix断图问题 推荐