zabbix在模板中预定义了一些key,但通常情况,并不能满足我们的需求。幸运的是zabbix提供了自定义key的方法,因此我们可以灵活的监控各种我们想要监控的数据。
定义配置文件
通过yum安装的zabbix-agent
配置文件路径为/etc/zabbix/zabbix_agentd.conf
。
大约在这个文件的255行
左右,我们可以发现下面的代码:
Include=/etc/zabbix/zabbix_agentd.d/
我们自定义的配置,可以放到这个目录。
我们可以创建一个自定义的文件来定义我们需要的key:vim /etc/zabbix/zabbix_agent.d/userparameter_script.conf
文件里面添加这样的内容:
# 这个文件监控自定义脚本输出值
# 格式为UserParameter=<key>,<command>
UserParameter=script.date,date
保存之后重启zabbix-agent。
测试获取自定义key的值
在zabbix-server上使用zabbix_get工具获取自定义值。
shell > zabbix_get -s 100.10.1.2 -k script.date
Fri Apr 24 14:41:18 CST 2015
获取到了上面例子中执行date的结果,说明配置是成功的。
创建一个脚本
首先新建一个script目录来存放我们的脚本,并将这个脚本命名为kucun.sh,我将使用zabbix来监控数据库中的库存表,使用库存数据画图。
mkdir -p /etc/zabbix/script/
vim /etc/zabbix/script/kucun.sh
我们定义脚本,输入一个店铺号来查询这个店铺中商品数量小于n的条数。
若手动执行查询,查询方式是这样的:
shell> /etc/zabbix/script/kucun.sh bj001 30
2
输出2即表示有2个商品数量小于30。
下面是脚本的内容:
#!/bin/bash
shop_id=$1
number=$2
dbhost="100.10.1.2"
dbuser="monitor"
dbpasswd="21"
sql="SELECT count(*) FROM lsp_cus.menu WHERE shop_no = \"$shop_id\" AND date = UNIX_TIMESTAMP(DATE_FORMAT(NOW(),'%Y-%m-%d')) AND num - sale < \"$number\""
mysql -h$dbhost -u$dbuser -p$dbpasswd -Ne "$sql"
使用脚本查询的结果创建key
重新编辑
vim /etc/zabbix/zabbix_agent.d/userparameter_script.conf
文件修改为:
# 这个文件监控自定义脚本输出值
# 格式为UserParameter=<key>,<command>
UserParameter=script.kucun[*],/etc/zabbix/script/kucun.sh $1 $2
通过zabbix-server查询
在zabbix服务器上使用zabbix_get工具查询店铺号001,库存小于30的商品数量。
shell> zabbix_get -s 100.10.1.2 -k script.kucun[001,30]
18
可以看到成功了。
上面用到方法的一些解释
UserParameter=key[*],command
key
为唯一值,[*]
表示参数。command
为要执行的命令或脚本,key
的[*]
里面的参数一一对应$1
到$9
,一共9个参数。$0
表示脚本命令。返回结果数据最大为512KB
。
参数禁止使用下列字符:\ ‘ ” ` * ? [ ] { } ~ $ ! & ; ( ) <> | # @
脚本的命令行参数可以通过搜索引擎搜索相关文章。
UserParameter=script.date,date
我是root用户,可是当我输入完这个之后,提示E212: Can't open file for writing,又要搞权限,太囧了。