me小怪兽

导航

< 2025年3月 >
23 24 25 26 27 28 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 1 2 3 4 5

统计

zabbix监控mysql主从状态

 

zabbix_agent端配置
1)脚本编写(修改mysql的用户名和密码)
[root@mysql_slave script]# cat /etc/zabbix/script/mysql_slave_status.sh

复制代码
#!/bin/bash
#用于获取主从同步信息,判断主从是否出现异常,然后提交给zabbix
USER="test"
PASSWD="root123"
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
复制代码

脚本测试,0表示正常,1表示异常
[root@mysql_slave script]# sh slave_status.sh io
0
[root@mysql_slave script]# sh slave_status.sh sql
0

2)agent配置文件修改,编写一个自配置文件,里面指定上面编写的脚本的路径
[root@mysql_slave ~]# cd /etc/zabbix/zabbix_agentd.d/
[root@mysql_slave zabbix_agentd.d]# cat userparameter_mysql_slave.conf
# 获取MySQL slave状态
UserParameter=mysql.slave[*],/etc/zabbix/script/mysql_slvae_status.sh $1

3)重启zabbix-agent
[root@mysql_slave ~]#  systemctl restart zabbix-agent.service


4)在zabbix-server端进行测试,看是否能够成功获取到值,通过上面的脚本,这里为0即表示正常,为1即表示不正常。
[root@mysql_slave ~]#  zabbix_get -s 172.25.8.143 -k mysql.slave[sql]
0
[root@mysql_slave ~]#  zabbix_get -s 172.25.8.143 -k mysql.slave[io]
0
server端web配置
1)配置Slave_IO_Running线程监控项,新建监控项

 

 

2)配置Slave_SQL_Running线程监控项,新建监控项

 

 



查看新添加的监控项

 

 



3)配置Slave_IO_Running线程的触发器,新建触发器

 

 

 

 



4)配置Slave_SQL_Running线程的触发器

 

 



5)配置图形展示,预览结果

 

 



总结
以上就是zabbix监控mysql主从的配置,如有疑问请下下方留言,我会第一时间回复大家的,感谢支持。

 

posted on   me小怪兽  阅读(339)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示