me小怪兽

导航

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 2022-02-25 16:48  me小怪兽  阅读(323)  评论(0编辑  收藏  举报