zabbix监控MySQL主从状态的方法详解

吾爱主题 阅读:113 2024-04-05 14:21:04 评论:0

搭建MySQL主从后,很多时候不知道从的状态是否ok,有时候出现异常不能及时知道,这里通过shell脚本结合zabbix实现监控并告警

一般情况下,在MySQL的从上查看从的运行状态是通过Slave_IO_Running线程和Slave_SQL_Running线程是否ok,通过命令“show slave status\G;”即可查看。所以这里根据这两个值进行判断。

agent端脚本编写及配置

说明:所有zabbix相关的脚本我都放在了/etc/zabbix/script/ 目录里面,下面这些都是在zabbix被监控端上操作,并且上面数据库是属于MySQL主从的从

1)脚本编写

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 [root@srt-xt ~]# cd /etc/zabbix/script/ [root@srt-xt /etc/zabbix/script]# cat mysql_slvae_status.sh #!/bin/bash # Desc :用于获取主从同步信息,判断主从是否出现异常,然后提交给zabbix # Date : 2019-06-06 # by :Lee-YJ USER = "root" PASSWD= "nae3eabo9naeli1Oov1a" NAME =$1 function IO {    Slave_IO_Running=`mysql -u $ USER -p$PASSWD -e "show slave status\G;" 2> /dev/ null |grep Slave_IO_Running |awk '{print $2}' `    if [ $Slave_IO_Running == "Yes" ]; then      echo 0    else      echo 1    fi } function SQL {    Slave_SQL_Running=`mysql -u $ USER -p$PASSWD -e "show slave status\G;" 2> /dev/ null |grep Slave_SQL_Running: |awk '{print $2}' `    if [ $Slave_SQL_Running == "Yes" ]; then      echo 0    else      echo 1    fi } case $ NAME in    io)      IO    ;;    sql)      SQL    ;;    *)      echo -e "Usage: $0 [io | sql]" esac

2)配置文件修改,编写一个自配置文件,里面指定上面编写的脚本的路径

?
1 2 3 4 5 [root@srt-xt ~]# cd /etc/zabbix/zabbix_agentd.d/   [root@srt-xt /etc/zabbix/zabbix_agentd.d]# cat userparameter_mysql_slave.conf # 获取MySQL slave状态 UserParameter=mysql.slave[*],/etc/zabbix/script/mysql_slvae_status.sh $1

3)重启zabbix-agent

?
1 [root@srt-xt /etc/zabbix/zabbix_agentd.d]# /etc/init.d/zabbix-agent restart

4)在zabbix-server端进行测试,看是否能够成功获取到值,通过上面的脚本,这里为0即表示正常,为1即表示不正常。

?
1 2 3 4 [root@xxxxx ~]# zabbix_get -s 218.75.249.55 -k mysql.slave[sql] 0 [root@xxxxx ~]# zabbix_get -s 218.75.249.55 -k mysql.slave[io] 0

server端web配置

1)配置Slave_IO_Running线程监控项

2)配置Slave_SQL_Running线程监控项

3)配置Slave_IO_Running线程的触发器

4)配置Slave_SQL_Running线程的触发器

5)配置触发动作

配置动作中需要执行的动作(发送消息给管理员)

配置状态恢复时的操作(同样发送消息给管理员)

最终查看监控项

至此,就完成了MySQL主从中从的状态监控了。

总结

以上所述是小编给大家介绍的zabbix监控MySQL主从状态的方法详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

原文链接:https://www.cnblogs.com/yanjieli/archive/2019/06/10/10996843.html

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容