天天看点

zabbix获取mysql主从状态_zabbix--监控MySQL主从状态

zabbix监控mysql主从状态

搭建mysql主从后,很多时候不知道从的状态是否ok,有时候出现异常不能及时知道,这里通过shell脚本结合zabbix实现监控并告警

一般情况下,在mysql的从上查看从的运行状态是通过slave_io_running线程和slave_sql_running线程是否ok,通过命令“show slave status\g;”即可查看。所以这里根据这两个值进行判断。

zabbix获取mysql主从状态_zabbix--监控MySQL主从状态

agent端脚本编写及配置

说明:所有zabbix相关的脚本我都放在了/etc/zabbix/script/ 目录里面,下面这些都是在zabbix被监控端上操作,并且上面数据库是属于mysql主从的从

1)脚本编写

[[email protected] ~]# cd /etc/zabbix/script/

[[email protected] /etc/zabbix/script]# cat mysql_slvae_status.sh

#!/bin/bash

#desc:用于获取主从同步信息,判断主从是否出现异常,然后提交给zabbix

#date: 2019-06-06

#by:lee-yj

user="root"

passwd="nae3eabo9naeli1oov1a"

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

2)配置文件修改,编写一个自配置文件,里面指定上面编写的脚本的路径

[[email protected] ~]# cd /etc/zabbix/zabbix_agentd.d/

[[email protected] /etc/zabbix/zabbix_agentd.d]# cat userparameter_mysql_slave.conf

# 获取mysql slave状态

userparameter=mysql.slave[*],/etc/zabbix/script/mysql_slvae_status.sh $1

3)重启zabbix-agent

[[email protected] /etc/zabbix/zabbix_agentd.d]# /etc/init.d/zabbix-agent restart

4)在zabbix-server端进行测试,看是否能够成功获取到值,通过上面的脚本,这里为0即表示正常,为1即表示不正常。

[[email protected] ~]# zabbix_get -s 218.75.249.55 -k mysql.slave[sql]

[[email protected] ~]# zabbix_get -s 218.75.249.55 -k mysql.slave[io]

server端web配置

1)配置slave_io_running线程监控项

zabbix获取mysql主从状态_zabbix--监控MySQL主从状态

2)配置slave_sql_running线程监控项

zabbix获取mysql主从状态_zabbix--监控MySQL主从状态

3)配置slave_io_running线程的触发器

zabbix获取mysql主从状态_zabbix--监控MySQL主从状态

4)配置slave_sql_running线程的触发器

zabbix获取mysql主从状态_zabbix--监控MySQL主从状态

5)配置触发动作

zabbix获取mysql主从状态_zabbix--监控MySQL主从状态

配置动作中需要执行的动作(发送消息给管理员)

zabbix获取mysql主从状态_zabbix--监控MySQL主从状态

配置状态恢复时的操作(同样发送消息给管理员)

zabbix获取mysql主从状态_zabbix--监控MySQL主从状态

最终查看监控项

zabbix获取mysql主从状态_zabbix--监控MySQL主从状态

至此,就完成了mysql主从中从的状态监控了。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!