Zabbix实现监控多个mysql过程解析
作者:邯郸-小刀 时间:2024-01-25 20:24:53
一台服务器上开启了3个mysql实例进程,占用不同的端口 3306、3307、3308
原理说明:
通过自动发现规则来获取MySQL实例的端口,自动发现规则上的{$MYSQLPORT}是要传递给agent自动发现脚本的参数,这个值是从主机定义的宏{$MYSQLPORT}获取过来的,自动发现的脚本将其解析成{#MYSQLPORT}:端口的形式,监控项原型再根据{#MYSQLPORT}的值来生成监控项,大致流程如下:
主机定义宏{$MYSQLPORT}->自动发现规则键值{$MYSQLPORT}->调用agent上自动发现脚本并解析成{#MYSQLPORT} : 端口 ->监控项原型{#MYSQLPORT}->自动生成主机监控项
一、在mysql多实例服务器上的操作
1、授权zabbix监控mysql账号,在每个实例下都需要。
此处 账号为 zabbixagent,密码为: Zabbix131
GRANT USAGE,PROCESS,REPLICATION CLIENT,REPLICATION SLAVE ON *.* TO 'zabbixagent'@'localhost' IDENTIFIED BY 'Zabbix131';
flush privileges;
2、修改zabbix_agentd.conf配置文件
最后位置增加
UnsafeUserParameters=1
EnableRemoteCommands=1
Include=/etc/zabbix/etc/zabbix_agentd.conf.d/*.conf
[root@mysql zabbix]# vi /etc/zabbix/etc/zabbix_agentd.conf
UnsafeUserParameters=1
EnableRemoteCommands=1
Include=/etc/zabbix/etc/zabbix_agentd.conf.d/*.conf
3、增加配置文件
[root@mysql etc]# vim /etc/zabbix/etc/zabbix_agentd.conf.d/check_mysql.conf
UserParameter=mysql_discovery[*],/etc/zabbix/bin/discovery_mysql.sh $1 ###自动发现不同端口
UserParameter=mysql.status[*],/etc/zabbix/bin/mysql_status.sh $1 $2 ###性能监控信息
UserParameter=mysql.ping[*],/etc/zabbix/bin/mysql_alive.sh $1 ### 是否存活
UserParameter=mysql.ms.check[*],/etc/zabbix/bin/mysql_slave_status.sh $1 ### 从库状态是否正常
UserParameter=mysql.ms.time[*],/etc/zabbix/bin/mysql_slave_time.sh $1 ### 从库是否有延迟
4、增加执行脚本文件
[root@mysql etc]# ll /etc/zabbix/bin/
total 716
-rwxr-xr-x 1 root root 441 Jul 22 11:36 discovery_mysql.sh
-rwxr-xr-x 1 root root 401 Jul 22 11:36 mysql_alive.sh
-rwxr-xr-x 1 root root 303 Jul 22 15:10 mysql_slave_status.sh
-rwxr-xr-x 1 root root 286 Jul 22 15:10 mysql_slave_time.sh
-rwxr-xr-x 1 root root 299 Jul 22 11:36 mysql_status.sh
-rwxr-xr-x 1 root root 370 Jul 22 11:36 mysql_version.sh
[root@mysql etc]# more /etc/zabbix/bin/discovery_mysql.sh
res=`echo $1| sed "s/_/\n/g"`;
port=($res)
printf '{\n'
printf '\t"data":[\n'
for key in ${!port[@]}
do
if [[ "${#port[@]}" -gt 1 && "${key}" -ne "$((${#port[@]}-1))" ]];
then
printf '\t {\n'
printf "\t\t\t\"{#MYSQLPORT}\":\"${port[${key}]}\"},\n"
else [[ "${key}" -eq "((${#port[@]}-1))" ]]
printf '\t {\n'
printf "\t\t\t\"{#MYSQLPORT}\":\"${port[${key}]}\"}\n"
fi
done
printf '\t ]\n'
printf '}\n'
[root@mysql etc]# more /etc/zabbix/bin/mysql_status.sh
#!/bin/bash
var=$1
mysql=/usr/local/mysql/bin/mysql
MYSQL_USER="zabbixagent"
MYSQL_PASSWORD=Zabbix131
MYSQL_SOCK_DIR="/tmp/mysql$2.sock"
${mysql} -u${MYSQL_USER} -p${MYSQL_PASSWORD} -S ${MYSQL_SOCK_DIR} -e "show global status;" 2> /dev/null |grep -v Variable_name|grep "\b${var}\b"|awk '{print $2}'
[root@mysql etc]# more /etc/zabbix/bin/mysql_alive.sh
#!/bin/bash
mysqladmin=/usr/local/mysql/bin/mysqladmin
MYSQL_USERdd="zabbixagent"
MYSQL_PASSWORD=Zabbix131
MYSQL_SOCK_DIR="/tmp/mysql$1.sock"
${mysqladmin} -u${MYSQL_USER} -p${MYSQL_PASSWORD} -S ${MYSQL_SOCK_DIR} ping|grep -c alive
[root@mysql etc]# more /etc/zabbix/bin/mysql_slave_status.sh
#!/bin/bash
#var=$1
mysql=/usr/local/mysql/bin/mysql
MYSQL_USERdd="zabbixagent"
MYSQL_PASSWORD=Zabbix131
MYSQL_SOCK_DIR="/tmp/mysql$1.sock"
${mysql} -u${MYSQL_USER} -p${MYSQL_PASSWORD} -S ${MYSQL_SOCK_DIR} -e "show slave status\G;" 2> /dev/null|grep -E 'Slave_IO_Running: Yes|Slave_SQL_Running: Yes'|grep -c Yes
[root@mysql etc]# more /etc/zabbix/bin/mysql_slave_time.sh
#!/bin/bash
#var=$1
mysql=/usr/local/mysql/bin/mysql
MYSQL_USERdd="zabbixagent"
MYSQL_PASSWORD=Zabbix131
MYSQL_SOCK_DIR="/tmp/mysql$1.sock"
${mysql} -u${MYSQL_USER} -p${MYSQL_PASSWORD} -S ${MYSQL_SOCK_DIR} -e "show slave status\G;" 2> /dev/null|grep -E 'Seconds_Behind_Master'|awk '{print $2}'
5、重启 zabbix_agentd
[root@mysql zabbix_agentd.d]# systemctl restart zabbix-agent
二、zabbix页面上操作
1、导入template_multi_MySQL.xml 模板信息,也可以参考xml文件手动增加。
2、在模版上创建自动发现的规则,在自动发现规则中需要定义两个东西:
a.键值 用来自动获取MySQL实例的端口,需要使用到主机宏{$MYSQLPORT}
b.监控项原型 根据获取的端口来生成对应的监控项,需要使用到自动发现宏{#MYSQLPORT}
3、在需要监控的主机上增加新创建的模板
4、在需要监控的主机上定义一个宏{$MYSQLPORT},对应要监控的端口,如3306_3307_3308
三、等待收集数据完成,如果没有数据的话,手动测试下具体
例如在zabbixserver上执行操作,例如测试mysql 3306是否存活,1表示up,0表示down。
最终的效果是
Zabbix131
来源:https://www.cnblogs.com/xzlive/p/13362414.html
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Python中Selenium模拟JQuery滑动解锁实例
![](https://img.aspxhome.com/file/2023/0/124640_0s.png)
Python+tkinter编写一个最近很火的强制表白神器
![](https://img.aspxhome.com/file/2023/5/121405_0s.png)
打开电脑上的QQ的python代码
vue中项目页面空白但不报错产生的原因及分析
![](https://img.aspxhome.com/file/2023/8/130188_0s.png)
好用的Python编辑器WingIDE的使用经验总结
![](https://img.aspxhome.com/file/2023/0/100290_0s.png)
NCCL深度学习Bootstrap网络连接建立源码解析
![](https://img.aspxhome.com/file/2023/3/82823_0s.jpg)
python多线程调用exit无法退出的解决方法
Python Counting Bloom Filter原理与实现详细介绍
![](https://img.aspxhome.com/file/2023/7/128217_0s.png)
JavaScript生成.xls文件的代码
![](https://img.aspxhome.com/file/2023/3/136053_0s.png)
javascript attachEvent绑定多个事件执行顺序问题
python判断变量是否为列表的方法
![](https://img.aspxhome.com/file/2023/9/109439_0s.png)
python实现飞机大战(面向过程)
![](https://img.aspxhome.com/file/2023/0/97110_0s.jpg)
解决bootstrap中使用modal加载kindeditor时弹出层文本框不能输入的问题
python中异常捕获方法详解
Numpy 中的矩阵求逆实例
Python编程快速上手——疯狂填词程序实现方法分析
![](https://img.aspxhome.com/file/2023/5/61475_0s.png)
一个基于flask的web应用诞生(1)
![](https://img.aspxhome.com/file/2023/5/127925_0s.png)
用OpenCV将视频分解成单帧图片,图片合成视频示例
python如何使用代码运行助手
![](https://img.aspxhome.com/file/2023/4/89184_0s.png)
使用Python实现二分法查找的示例
![](https://img.aspxhome.com/file/2023/9/85379_0s.png)