当前位置:主页 > 查看内容

一文教你学会用Zabbix监控MySQL数据库

发布时间:2021-04-21 00:00| 位朋友查看

简介:前面讲到如何监控PG和MS SQL,今天带来另外一个数据库(MySQL)的教程。MySQL相比于PG和MS SQL监控难度最小,因为比较成熟,而且使用广泛,自然监控手段就没那么复杂,当然因为是基础篇,所以才说难度较低,监控的指标依照官方模板,对于初学者来说足够使用了……

前面讲到如何监控PG和MS SQL,今天带来另外一个数据库(MySQL)的教程。MySQL相比于PG和MS SQL监控难度最小,因为比较成熟,而且使用广泛,自然监控手段就没那么复杂,当然因为是基础篇,所以才说难度较低,监控的指标依照官方模板,对于初学者来说足够使用了。如果有深入的监控需求,那就需要和业务方沟通,根据监控的范围来制作自定义指标了。

正文

环境

  • Zabbix版本:5.2.2
  • MySQL版本:10.3.17
  • 系统版本:CentOS 8.2

监控范围

Zabbix自身数据库

模板获取方式

  • 通过网上资源
  • 通过官方git仓库(如下图)

为了方便各位直接能粘贴,贴出相对应的语句

  1. vi /etc/zabbix/zabbix_agentd.d/template_db_mysql.conf 
  2. <---------------------------------------------------------------------------------------------------------------------------------------------------------------------> 
  3. UserParameter=mysql.ping[*], mysqladmin -h"$1" -P"$2" ping 
  4. UserParameter=mysql.get_status_variables[*], mysql -h"$1" -P"$2" -sNX -e "show global status" 
  5. UserParameter=mysql.version[*], mysqladmin -s -h"$1" -P"$2" version 
  6. UserParameter=mysql.db.discovery[*], mysql -h"$1" -P"$2" -sN -e "show databases" 
  7. UserParameter=mysql.dbsize[*], mysql -h"$1" -P"$2" -sN -e "SELECT COALESCE(SUM(DATA_LENGTH + INDEX_LENGTH),0) FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA='$3'" 
  8. UserParameter=mysql.replication.discovery[*], mysql -h"$1" -P"$2" -sNX -e "show slave status" 
  9. UserParameter=mysql.slave_status[*], mysql -h"$1" -P"$2" -sNX -e "show slave status" 

 

效果图

自定义监控脚本启用

编辑agent配置文件,填写如下图红框中的内容(默认有)

  1. vim /etc/zabbix/zabbix_agentd.conf 

 

创建数据库监控用户

下面的命令基于我自身的环境,自身环境请根据自身的环境调整。

  1. mysql -uroot -pxiaoyu123  
  2. CREATE USER 'kasar'@'%' IDENTIFIED BY 'xiaoyu123';  
  3. GRANT USAGE,REPLICATION CLIENT,PROCESS,SHOW DATABASES,SHOW VIEW ON *.* TO 'kasar'@'%'

 

创建登录用户名密码文件

默认在zabbix agent家目录(/var/lib/zabbix)下,如果没有,请创建。该文件主要是用于zabbix登录mysql数据库使用的。

  1. mkdir /var/lib/zabbix 
  2. vi /var/lib/zabbix/.my.cnf 
  3. [client]  
  4. user='kasar'  
  5. password='xiaoyu123' 

 

前端调用MySQL模板

4.0以上默认是有该模板的,无需要下载,如果没有也可以按照我上面讲的方法去获取,也可以私信找我要。


重启zabbix agent

  1. service zabbix-agent restart 

 

数据显示正常


出图正常

写在最后

整个过程不太难,当然要理解其中模板的调用关系还是稍微有点复杂,只有了解了Zabbix自定义监控脚本才能更深层次监控MySQL数据库,当然这个是后话了,先要从0到1,才能更好的进步,毕竟千里之行,始于足下嘛。


本文转载自网络,原文链接:https://www.toutiao.com/i6908579900274328076/
本站部分内容转载于网络,版权归原作者所有,转载之目的在于传播更多优秀技术内容,如有侵权请联系QQ/微信:153890879删除,谢谢!

推荐图文


随机推荐