1818IP-服务器技术教程,云服务器评测推荐,服务器系统排错处理,环境搭建,攻击防护等

当前位置:首页 - 运维 - 正文

君子好学,自强不息!

Zabbix 自动发现并监控 MySQL

2022-11-06 | 运维 | gtxyzz | 590°c
A+ A-

一、方案需求及思路

因跑MySQL服务的服务器比较多,并且每台服务器可能会运行多个不同端口的数据库,如果单独手动一台一台去修改agent.conf,web添加监控,这样太麻烦,费时费力。此时有两种方案;其一:在每台跑mysql的服务器上部署一个自动发现脚本,修改agent.conf 并自定义KEY;其二:统一由一台服务器来监控所有服务器上所有运行的mysql服务。发现好像方案二比较更简便些。

方案二思路:

假设有A、B、C、D、E五台服务器,上面都跑有mysql,并且每台都跑有2+个mysql,在此假定由A服务器来监控所有服务器上mysql的状态。此时需要先把五台服务器的IP及其上mysql服务所占用的port 记录下来,统一写到一个文件里:eg:

192.168.12.143306
192.168.12.143307
192.168.12.153308
192.168.12.153380
……

把该文件放到zabbix 目录下的某一个目录,并赋权限,再写一个json的脚本来调取此文件,并且需要在执行脚本文件的时候来进行IP传值并输出该IP上所有的port。

添加自定义key。其中需要定义一个自动发现的key,然后定义一个根据IP查询此服务器上所有端口的mysql状态的key。重启zabbix_agentd,通过zabbix_get来获取参数看看是否正常。

配置web界面。在web配置界面中,创建一个主机,该主机的ip指向A服务器的IP,切该服务器的[HOST.NAME] 指向所要监控mysql的IP,([HOST.NAME]一般指的是”Visable name”),把监控mysql的服务器都指向一个组,然后调用自动发现mysql模版。之后在创建剩下的几台服务器即可。

此方案也不是一个很好的方案,但相对来说还是不错的,以后若有新增加的mysql服务器,只需要修改写有IP和PORT的列表文件即可,不需要重启agent。

二、配置Agent:

1、编辑mysqld文件

#cat/usr/local/zabbix/bin/mysqld
172.16.8.2503306
172.16.8.2503309
172.16.8.2523306
172.16.8.2523307

注:本文均在8.250上实现监控252上的数据库及本地250的数据库

2、mysql赋权限

分别将四个数据库都赋给172.16.8.250主机以用户zabbix,密码111的访问,show global status权限。

3、编辑discovery_mysql.sh

#cat/usr/local/zabbix/bin/discovery_mysql.sh
#!/bin/bash
#mysqllow-leveldiscovery
#Script_namediscovery_mysql.sh
res=`cat/usr/local/zabbix/bin/mysqld|grep$1|grep-v"^#"|awk'{print$2}'`
port=($res)
printf'{\n'
printf'\t"data":[\n'
forkeyin${!port[@]}
do
if[["${#port[@]}"-gt1&&"${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'

赋执行权限:

#chmod+x/usr/local/zabbix/bin/discovery_mysql.sh

测试执行效果:

#sh/usr/local/zabbix/bin/discovery_mysql.sh172.16.8.250
{
"data":[
{
"{#MYSQLPORT}":"3306"},
{
"{#MYSQLPORT}":"3309"}
]
}

把上述结果粘贴到json检测网站,查看结果是否正确 http://jsonlint.com/

4、修改agentd.conf

开启include选项

Include=/usr/local/zabbix/etc/zabbix_agentd/

添加mysql自动发现规则,自定义key

#cat/usr/local/zabbix/etc/zabbix_agentd/mysql_discovery.conf
####$1==IP$2==PORT$3==COMMAND
UserParameter=zabbix_low_discovery[*],/bin/bash/usr/local/zabbix/bin/discovery.sh$1
UserParameter=mysql_stats[*],mysql-uzabbix-p111-P$2-h$1-e"showglobalstatus"|grep"\<$3\>"|cut-f2
UserParameter=mysql.alive[*],mysqladmin-uzabbix-p111-h$1-P$2ping|grep-calive

5、测试:

重启zabbix_agentd,在zabbix server中通过zabbix_get测试zabbix mysql自动发现规则是否正确。

注:172.16.8.250是zabbix server,agent地址为127.0.0.1,请根据自己情况修改下面命令。

#zabbix_get-s127.0.0.1-kzabbix_log_discovery[172.16.8.250]
{
"data":[
{
"{#MYSQLPORT}":"3306"},
{
"{#MYSQLPORT}":"3309"}
]
}
#zabbix_get-s127.0.0.1-kmysql_stats[172.16.8.250,3306,Uptime]

可正确取得数据便为正确,

转载请注明

本文来源:1818IP

本文地址:https://www.1818ip.com/post/7380.html

免责声明:本文由用户上传,如有侵权请联系删除!

发表评论

必填

选填

选填

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。