视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Zabbix自动发现并监控MySQL_MySQL
2020-11-09 19:19:06 责编:小采
文档
 一、方案需求及思路

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

方案二思路:

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

  1. 192.168.12.14 3306
  2. 192.168.12.14 3307
  3. 192.168.12.15 3308
  4. 192.168.12.15 3380
  5. ……

把该文件放到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文件

  1. # cat /usr/local/zabbix/bin/mysqld
  2. 172.16.8.250 3306
  3. 172.16.8.250 3309
  4. 172.16.8.252 3306
  5. 172.16.8.252 3307

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

2、mysql赋权限

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

3、编辑discovery_mysql.sh

  1. # cat /usr/local/zabbix/bin/discovery_mysql.sh
  2. #!/bin/bash
  3. #mysql low-level discovery
  4. #Script_name discovery_mysql.sh
  5. res=`cat /usr/local/zabbix/bin/mysqld|grep $1|grep -v "^#"|awk '{print $2}'`
  6. port=($res)
  7. printf '{/n'
  8. printf '/t"data":[/n'
  9. for key in ${!port[@]}
  10. do
  11. if [[ "${#port[@]}" -gt 1 && "${key}" -ne "$((${#port[@]}-1))" ]];then
  12. printf '/t {/n'
  13. printf "/t/t/t/"{#MYSQLPORT}/":/"${port[${key}]}/"},/n"
  14. else [[ "${key}" -eq "((${#port[@]}-1))" ]]
  15. printf '/t {/n'
  16. printf "/t/t/t/"{#MYSQLPORT}/":/"${port[${key}]}/"}/n"
  17. fi
  18. done
  19. printf '/t ]/n'
  20. printf '}/n'

赋执行权限:

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

测试执行效果:

  1. # sh /usr/local/zabbix/bin/discovery_mysql.sh 172.16.8.250
  2. {
  3. "data":[
  4. {
  5. "{#MYSQLPORT}":"3306"},
  6. {
  7. "{#MYSQLPORT}":"3309"}
  8. ]
  9. }

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

4、修改agentd.conf

开启include选项

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

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

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

5、测试:

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

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

  1. # zabbix_get -s 127.0.0.1 -k zabbix_log_discovery[172.16.8.250]
  2. {
  3. "data":[
  4. {
  5. "{#MYSQLPORT}":"3306"},
  6. {
  7. "{#MYSQLPORT}":"3309"}
  8. ]
  9. }
  10. # zabbix_get -s 127.0.0.1 -k mysql_stats[172.16.8.250,3306,Uptime]

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

转载请注明原文出处:http://www.minunix.com/2014/04/zabbix_low_discovery_mysql_01/

三、Zabbix WEB 添加主机

1、导入模版discovery_mysql.xml

2、添加主机:

链接模版:

注:因模版定义的更新时间为3600s,如需快速看到效果,可先修改模版自定义规则的“Interval”更新时间改为60,之后便可再”last data”中看到数据。

监控172.16.8.252,只需要创建主机,将visable name 的值172.16.8.250 改为172.16.8.252即可。

下载本文
显示全文
专题