zabbix--监控MySQL主从状态
2024-08-23 07:19:25
zabbix监控MySQL主从状态
搭建MySQL主从后,很多时候不知道从的状态是否ok,有时候出现异常不能及时知道,这里通过shell脚本结合zabbix实现监控并告警
一般情况下,在MySQL的从上查看从的运行状态是通过Slave_IO_Running线程和Slave_SQL_Running线程是否ok,通过命令“show slave status\G;”即可查看。所以这里根据这两个值进行判断。
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: --
#by:Lee-YJ USER="root"
PASSWD="nae3eabo9naeli1Oov1a"
NAME=$ function IO {
Slave_IO_Running=`mysql -u $USER -p$PASSWD -e "show slave status\G;" > /dev/null |grep Slave_IO_Running |awk '{print $2}'`
if [ $Slave_IO_Running == "Yes" ];then
echo
else
echo
fi
} function SQL {
Slave_SQL_Running=`mysql -u $USER -p$PASSWD -e "show slave status\G;" > /dev/null |grep Slave_SQL_Running: |awk '{print $2}'`
if [ $Slave_SQL_Running == "Yes" ];then
echo
else
echo
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 $
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] [root@xxxxx ~]# zabbix_get -s 218.75.249.55 -k mysql.slave[io]
server端web配置
1)配置Slave_IO_Running线程监控项
2)配置Slave_SQL_Running线程监控项
3)配置Slave_IO_Running线程的触发器
4)配置Slave_SQL_Running线程的触发器
5)配置触发动作
配置动作中需要执行的动作(发送消息给管理员)
配置状态恢复时的操作(同样发送消息给管理员)
最终查看监控项
至此,就完成了MySQL主从中从的状态监控了。
最新文章
- 编写可维护的JavaScript代码
- Android开发学习之路-使用AsyncTask进行异步操作
- 为什么你找不到优秀的GISer?
- java中多线程中Runnable接口和Thread类介绍
- tiff或tif文件的读取
- scala构造器实战
- makefile实例(3)-多个文件实例优化
- BitNami一键安装Redmine(转)
- [Android学习笔记]组合控件的使用
- 归并排序—Java版
- 【原创】运维基础之yum离线环境安装软件
- 设计模式のSingleton Pattern(单例模式)----创建模式
- Docker 随 docker服务重启
- selenium的webdriver三种等待方式(显式等待WebDriverWait+implicitly_wait隐式等待+sleep强制等待)
- 比较sql server两个数据库
- mysql之表的查看操作
- Vakuum开发笔记01 开天辟地
- javascript数据结构与算法--基本排序算法(冒泡、选择、排序)及效率比较
- 十图详解TensorFlow数据读取机制(附代码)
- [转]Activitys, Threads, &; Memory Leaks
热门文章
- 11-散列4 Hashing - Hard Version (30 分)
- 第02组 Alpha冲刺(2/6)
- mysql(七)查询基本语法
- 【技术博客】nginx服务器的https协议实现
- 一道经典的Java面试题:equals ,== 和hashcode()的区别
- k8s删除pod一直处于terminating状态
- Docker快速搭建Zookeeper和kafka集群
- .Net Core 基于 SnmpSharpNet 开发
- 前端与算法 leetcode 125. 验证回文串
- Mysql常见注意事项小记