辉哥用的这种方法实现ZABBIX的MYSQL批量监控-阿里云开发者社区

开发者社区> 数据库> 正文

辉哥用的这种方法实现ZABBIX的MYSQL批量监控

简介:

不错的。集中和分布式,总是一对要解决的问题。应该可以再想更好的策略~~

 

 

一、方案需求及思路

因跑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. "data":[ 
  3. "{#MYSQLPORT}":"3306"}, 
  4. "{#MYSQLPORT}":"3309"} 

把上述结果粘贴到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. "data":[ 
  3. "{#MYSQLPORT}":"3306"}, 
  4. "{#MYSQLPORT}":"3309"} 
  5. # 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即可。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
数据库
使用钉钉扫一扫加入圈子
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

其他文章