背景:mysql
zabbix自己提供了不少可选的监控项,能够知足绝大部分的监控需求。有时候因为业务需求,须要自定义监控项。 下面以建立mysql自定义监控项为例,分享如何建立zabbix自定义监控项。web
环境说明:sql
zabbix版本:3.0.3 操做系统:CentOS 7 mysql版本:5.7.1数据库
实现步骤: 一、修改 zabbix_agentd.conf,添加zabbix_agent 配置目录,如下是我本机的zabbix的配置: 将如下行的注释去掉服务器
#Include=/usr/local/etc/zabbix_agentd.conf.d/*.conf
变成:测试
Include=/usr/local/etc/zabbix_agentd.conf.d/*.conf
将此行注释去掉后,zabbix_agentd启动后会自动扫描/usr/local/etc/zabbix_agentd.conf.d/目录下全部的.conf文件,并加载。操作系统
二、编写监控脚本/usr/local/zabbix/zabbix-script/get_mysql_status.sh,脚本以下(脚本存放目录能够自定义):code
#!/bin/sh case $3 in uptime) mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $2}' ;; threads) mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $4}' ;; question) mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $6}' ;; sq) mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $9}' ;; open) mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $11}' ;; ftable) mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $14}' ;; opent) mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $17}' ;; qps) mysqladmin -u$1 -p$2 status 2>/dev/nul | awk -F '[:| ]'+ '{print $22}' ;; *)
脚本说明,脚本须要输入三个参数分别是:mysql用户、mysql用户密码、mysql状态各项指标以下: uptime:运行时长单位s、 threads:开启的会话数、 question(questions):服务器启动以来客户的问题(查询)数目 sq(Slow queries): 慢查询数量 open(opens):服务器已经打开的数据库表的数量 ftable(Flush tables):服务器已经执行的flush ...、refresh和reload命令的数量 opent(open tables):经过命令是用的数据库的表的数量,以服务器启动开始 qps(Queries per second avg):select语句平均查询时间server
三、在/usr/local/etc/zabbix_agentd.conf.d/目录下添加监控项配置文件get_mysql_status.conf,内容以下:图片
UserParameter=get_mysql_status[*],/usr/local/zabbix/zabbix-script/get_mysql_status.sh $1 $2 $3
四、重启zabbix_agent和zabbix_server,使用zabbix_get测试,以下:
#zabbix_get -s 127.0.0.1 -k get_mysql_status[root,weiming,open] 679
五、web端添加监控项: 在主机上添加监控项:
添加完成后能够看到新增监控项以下:
添加图形:
图形预览:
如何添加
触发器这里就不细说了!