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主从的配置,如有疑问请下下方留言,我会第一时间回复大家的,感谢支持。