zabbix获取mysql主从状态_Zabbix监控MySQL主从状态

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

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

b703fe4e0f41a0d5b943b9466fbc1169.png

agent端脚本编写及配置

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

1)脚本编写

[root@srt-xt ~]# cd /etc/zabbix/script/

[root@srt-xt /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)配置文件修改,编写一个自配置文件,里面指定上面编写的脚本的路径

[root@srt-xt ~]# cd /etc/zabbix/zabbix_agentd.d/

[root@srt-xt /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

[root@srt-xt /etc/zabbix/zabbix_agentd.d]# /etc/init.d/zabbix-agent restart

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

[root@xxxxx ~]# zabbix_get -s 218.75.249.55 -k mysql.slave[sql]

0

[root@xxxxx ~]# zabbix_get -s 218.75.249.55 -k mysql.slave[io]

0

server端web配置

1)配置Slave_IO_Running线程监控项

44a6c64923bcb14c29e3beafa8cfe6da.png

2)配置Slave_SQL_Running线程监控项

b727ae2a2a0d1df7eb3fc730884a9393.png

3)配置Slave_IO_Running线程的触发器

4d9beabeab2fecb6c4cc8394725066b1.png

4)配置Slave_SQL_Running线程的触发器

76f5d2d5d0eda9b174fd30a0e928b550.png

5)配置触发动作

26e7823816c4741186199da54b1f7655.png

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

5e9144400aab173852958103d629a78c.png

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

ed3ef65774ac94089ced54954dd39447.png

最终查看监控项

2dec1d9a870e165df5d2e045f429d02c.png

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Zabbix中监视MySQL主从状态,需要执行以下步骤: 1. 确保MySQL主从复制已正确配置并正在运行。可以通过在主服务器上运行SHOW MASTER STATUS; 和在从服务器上运行SHOW SLAVE STATUS; 来检查复制状态。 2. 在MySQL主服务器上创建一个具有适当权限的MySQL用户以供Zabbix使用。可以使用以下命令创建用户: CREATE USER 'zabbix'@'localhost' IDENTIFIED BY 'password'; GRANT REPLICATION CLIENT ON *.* TO 'zabbix'@'localhost'; 3. 在Zabbix服务器上安装MySQL监视器模板。该模板包含用于监视MySQL服务器的预定义项和触发器。 4. 在Zabbix服务器上创建一个MySQL主服务器主机,将其与MySQL监视器模板关联,并配置主机的连接参数。这些参数应包括MySQL主服务器的IP地址、端口和上一步中创建的MySQL用户的凭据。 5. 在Zabbix服务器上创建一个MySQL从服务器主机,将其与MySQL监视器模板关联,并配置主机的连接参数。这些参数应包括MySQL从服务器的IP地址、端口和上一步中创建的MySQL用户的凭据。 6. 等待一段时间,以便Zabbix收集有关MySQL主从复制状态的数据。可以通过查看Zabbix监视器模板中的图形和报告来检查这些数据。 7. 如果需要,可以根据需要创建自定义Zabbix触发器,以便在MySQL主从复制状态出现问题时接收警报。 请注意,这只是一个基本的概述。实际的实施可能因环境和要求的不同而有所不同。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值