目录
zabbix监控mysql主从状态
搭建MySQL主从后,很多时候不知道从的状态是否ok,有时候出现异常不能及时知道,这里通过shell脚本结合zabbix实现监控并告警
在MySQL的从上查看从的运行状态是通过Slave_IO_Running线程和Slave_SQL_Running线程是否正常,通过命令“show slave status\\G;”即可查看。根据这两个值进行判断。
这里已经配置好主从
环境说明:
zabbix_server | 192.168.32.136 |
---|---|
zabbix_agent (mysql主) | 192.168.32.125 |
zabbix_agent(mysql从) | 192.168.32.130 |
1. 在从库上安装zabbix_agent,配置并添加到zabbix_server中
安装zabbix客户端
主机组自定义即可
2. 配置并编写监控脚本
[root@localhost ~]# vim /usr/local/etc/zabbix_agentd.conf
......
UnsafeUserParameters=1
......
UserParameter=mysql_master_status,/bin/bash /scripts/mysql_master_status.sh
#配置完成之后重启服务
[root@localhost ~]# vim /scripts/mysql_master_status.sh
#!/bin/bash
status=$(mysql -uroot -p123456 -e \'show slave status\\G\' 2>/dev/null |grep -E \'Slave_IO_Running|Slave_SQL_Running:\'|grep -c \'Yes\')
if [ $status -ne 2 ];then
echo \'1\'
else
echo \'0\'
fi
web页面配置监控项和触发器,验证
关闭从库的mysql,查看是否触发警告
[root@localhost ~]# systemctl stop mariadb
已经配置了发送邮件媒介和动作,触发警告时直接发送了邮件
mysql主从延迟监控
过命令“show slave status\\G;”获取Seconds_Behind_Master这一项的值,可以作为主从延迟的值
1. 配置并编写监控脚本
[root@localhost ~]# vim /scripts/mysql_delay
#!/bin/bash
delay=$(mysql -uroot -p123456 -e \'show slave status\\G\' 2>/dev/null|grep \'Seconds_Behind_Master\'|awk \'{print $2}\')
echo $delay
#编辑配置文件
UnsafeUserParameters=1
......
### Option: UserParameter
# User-defined parameter to monitor. There can be several user-defined parameters.
# Format: UserParameter=<key>,<shell command>
# See \'zabbix_agentd\' directory for examples.
#
# Mandatory: no
# Default:
# UserParameter=
UserParameter=mysql_master_status,/bin/bash /scripts/mysql_master_status.sh
UserParameter=mysql_delay,/bin/bash /scripts/mysql_delay.sh
......
#重启服务
2. web页面配置监控和触发器,验证
应为主从没有数据,延迟值为0 ,所以修改触发器,延迟值为0的时候触发,来验证