用户定义参数可以用来帮助用户实现通过Zabbix agent执行非Zabbix原生的 agent check。
一条用户自定义参数配置应当使用以下语法:
UserParameter=<key>,<command>
key将在配置监控项时使用,用户自定义参数是由Zabbix agent来执行命令的。用户自定义参数参照agent check超时;如果超时时间到了,那么执行用户自定义参数的子进程将会被中止。
UserParameter=key[*],command
命令在执行时,引用key中指定的值
只对灵活的用户参数有效:
你可以在命令中9来引用监控项Key中的相应参数。
Zabbix解析监控项Key的[]中包含的参数,并相应地替换9。
实现步骤
1.修改 zabbix_agentd.conf,添加zabbix_agent 配置目录,以下是我本机的zabbix的配置: 将以下行的注释去掉
#Include=/usr/local/etc/zabbix_agentd.conf.d/*.conf
2.编写监控脚本/usr/local/zabbix/zabbix-script/get_mysql_status.sh,脚本如下(脚本存放目录可以自定义):
#!/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}'
;;
*)
UserParameter=ping[*],/bin/echo $[`echo $(ping -q -i 0.5 -w 1 $1) | grep -Po "\w+(?=%\s)"`+100]
脚本说明,脚本需要输入三个参数分别是: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语句平均查询时间
3.在/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
4.重启zabbix_agent和zabbix_server,使用zabbix_get测试,如下:
#zabbix_get -s 127.0.0.1 -k get_mysql_status[root,weiming,open]
679
5.web端添加监控项: 在主机上添加监控项:
添加完的监控项
触发器
参考链接 :
zabbix自定义监控项: https://www.jianshu.com/p/1934ea829085