zabbix自带的模板基本上已经能满足大部分的监控需求,对于一些特殊指标需要自己定义key,企业中也需要自定义模板,以mysql主从为例,自定义监控项
首先mysql主从复制的关键指标在于都为Yes
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
所以可以通过grep 查询关键词yes=2来判断(推荐使用脚本,由于简单直接使用命令行)
mysql -uroot -pHuawei12#$ -e "show slave status\G;" 2>/dev/null | grep -wE "Slave_IO_Running|Slave_SQL_Running" | grep -c Yes
vim /usr/local/zabbix/etc/zabbix_agentd.conf
添加以下2行
#开启自定义key
UnsafeUserParameters=1
#自定义mysql.copy变量
UserParameter=mysql.copy,mysql -uroot -pHuawei12#$ -e "show slave status\G;"2>/dev/null |grep -wE "Slave_IO_Running|Slave_SQL_Running" |grep -c Yes
重启agent
/etc/init.d/zabbix_agentd restart
/usr/local/zabbix/bin/zabbix_get -s 192.168.197.130 -k mysql.copy
配置-主机-监控项(键值要填写自定义变量名称mysql_copy)
触发条件:当mysql_copy不等于2就报警
关闭主从复制测试
mysql -uroot -pHuawei12#$ -e "stop slave;"
mysql -uroot -pHuawei12#$ -e "show slave status\G;"
监控指标发生变化
告警信息,并发送钉钉和邮箱告警
钉钉告警
邮箱告警
在slave端开启主从复制
mysql -uroot -pHuawei12#$ -e "start slave;"
钉钉恢复告警
恢复邮箱告警
原文:https://blog.51cto.com/11442747/2515160