zabbix 自定义 key (转)

转自:http://www.cnblogs.com/miclesvic/p/6164303.html

1、在zabbix_agent端zabbix_agentd.conf配置文件中增加自定义Key(/usr/local/zabbix_agent/etc/zabbix_agentd.conf)

### Option: UserParameter
#       User-defined parameter to monitor. There can be several user-defined parameters.
#       Format: UserParameter=<key>,<shell command>
#       See ‘zabbix_agentd‘ directory for examples.
#
# Mandatory: no接
# Default:
# UserParameter=

UserParameter=Physical_cpu_0_temperature,sensors|grep "id 0"|awk ‘{print $4}‘|awk -F "°" ‘{print $1}‘|awk -F "+" ‘{print $2}‘
     变量    Key                                命令

就样一个自定义的Key就完成了,那么我们要怎么来测试这个Key是否生效了呢?配置文件修改完成后需要重启zabbix_agentd端的服务,然后在zabbix_server端通过zabbix_get查看,是否可以获取到值,如果获取到值,表明这个Key就设置成功了。

设置完Key一定记得要通过命令进行验证啊!!!
# zabbix_get -s 10.16.1.201 -p 10050 -k Physical_cpu_0_temperature
59.0

我们看下,CPU的温度已经可以正常获取了,我们的key就设置成功了!

说了第一种定义Key的方法,是在zabbix_agend.conf的主配置文件中修改,大家可以想想,如果需要定义100个Key的话,都写在主配置文件里,是不是主配置文件会很乱啊,那我们来看看有什么更好的方法呢,接下来看看第二种方法吧!

2、将Key定义在独立的文件中,然后在主配置文件中进行新引用就好了,下面我们来配置下。

2.1 修改zabbix_agentd.conf 配置(/usr/local/zabbix_agent/etc/zabbix_agentd.conf)

cat /usr/local/zabbix_agent/etc/zabbix_agentd.conf      # 在zabbix_agentd.conf配置文件中通过Include引用自定义Key文件目录
### Option: Include
#       You may include individual files or all files in a directory in the configuration file.
#       Installing Zabbix will create include directory in /usr/local/etc, unless modified during the compile time.
#
# Mandatory: no
# Default:
# Include=
# Include=/usr/local/etc/zabbix_agentd.userparams.conf
Include=/usr/local/zabbix_agent/etc/zabbix_agentd.conf.d/

2.2 在/usr/local/zabbix_agent/etc/zabbix_agentd.conf.d目录写编写自定义Key文件

# cat custom_parameters.conf
# Monitor CPU temperature
# cpu_core_0
UserParameter=Physical_cpu_0_temperature,sensors|grep "id 0"|awk ‘{print $4}‘|awk -F "°" ‘{print $1}‘|awk -F "+" ‘{print $2}‘
UserParameter=cpu_0_core0,sensors|grep -A 6 "id 0" | grep "Core 0" | awk ‘{print $3}‘|awk -F "°" ‘{print $1}‘|awk  -F "+" ‘{print $2}‘
UserParameter=cpu_0_core1,sensors|grep -A 6 "id 0" | grep "Core 1" | awk ‘{print $3}‘|awk -F "°" ‘{print $1}‘|awk  -F "+" ‘{print $2}‘
UserParameter=cpu_0_core2,sensors|grep -A 6 "id 0" | grep "Core 2" | awk ‘{print $3}‘|awk -F "°" ‘{print $1}‘|awk  -F "+" ‘{print $2}‘
UserParameter=cpu_0_core3,sensors|grep -A 6 "id 0" | grep "Core 3" | awk ‘{print $3}‘|awk -F "°" ‘{print $1}‘|awk  -F "+" ‘{print $2}‘
UserParameter=cpu_0_core4,sensors|grep -A 6 "id 0" | grep "Core 4" | awk ‘{print $3}‘|awk -F "°" ‘{print $1}‘|awk  -F "+" ‘{print $2}‘
UserParameter=cpu_0_core5,sensors|grep -A 6 "id 0" | grep "Core 5" | awk ‘{print $3}‘|awk -F "°" ‘{print $1}‘|awk  -F "+" ‘{print $2}‘

# cpu_core_1
UserParameter=Physical_cpu_1_temperature,sensors|grep "id 1"|awk ‘{print $4}‘|awk -F "°" ‘{print $1}‘|awk -F "+" ‘{print $2}‘
UserParameter=cpu_1_core0,sensors|grep -A 6 "id 1" | grep "Core 0" | awk ‘{print $3}‘|awk -F "°" ‘{print $1}‘|awk  -F "+" ‘{print $2}‘
UserParameter=cpu_1_core1,sensors|grep -A 6 "id 1" | grep "Core 1" | awk ‘{print $3}‘|awk -F "°" ‘{print $1}‘|awk  -F "+" ‘{print $2}‘
UserParameter=cpu_1_core2,sensors|grep -A 6 "id 1" | grep "Core 2" | awk ‘{print $3}‘|awk -F "°" ‘{print $1}‘|awk  -F "+" ‘{print $2}‘
UserParameter=cpu_1_core3,sensors|grep -A 6 "id 1" | grep "Core 3" | awk ‘{print $3}‘|awk -F "°" ‘{print $1}‘|awk  -F "+" ‘{print $2}‘
UserParameter=cpu_1_core4,sensors|grep -A 6 "id 1" | grep "Core 4" | awk ‘{print $3}‘|awk -F "°" ‘{print $1}‘|awk  -F "+" ‘{print $2}‘
UserParameter=cpu_1_core5,sensors|grep -A 6 "id 1" | grep "Core 5" | awk ‘{print $3}‘|awk -F "°" ‘{print $1}‘|awk  -F "+" ‘{print $2}‘

这让定义就可以了,如果需要定义的Key较多的话,我们就可以通过这种方式来定义key了,这样做的好处大家也可以很清楚的看到了,配置清晰、明了,而且不和主配置文件在一起,避免修改key影响主配置文件哈。记得修改完配置文件,记得重启zabbix_agent服务啊。最好还要通过上面介绍的方法进行验证下啊。

Key定义好了,我们来看看,如何在zabbix web页面通过这些来创建监控项吧!

3、zabbix web页面,通过创建的自定义Key来建立监控项

这里我们以一个自定义key来介绍了,多个key的创建方法一样哦,小伙伴们自己动手试下吧。

这是通过自定义监控一颗物理CPU温度汇总的图形,大家可以看到,自定义Key是不是很好用啊。只要我们在服务器上可以获取的值,都可以通过自定义Key的方法来进行监控,也非常的灵活!下面在来设置上监控温度的触发器吧。

创建

到这里,自定义Key我们就介绍完了,可以在回顾下,我们都做了什么?

1、在zabbix_agent端配置文件增加自定义Key

2、重启zabbix_agentd服务

3、在zabbix_server端通过zabbix_get验证自定义key是否生效

4、在zabbix_web页面通过自定义key创建监控项

5、在zabbix_web页面给自定义key监控项创建图形

6、自定义Key监控项创建触发器

时间: 2024-10-10 20:44:01

zabbix 自定义 key (转)的相关文章

zabbix自定义KEY监控服务状态[不需要端口]

zabbix监控Windows下的服务并实现告警和重启服务 首先 创建获取服务状态的脚本 一.Windows脚本 @echo off set srvname=%1 for /f "skip=3 tokens=4" %%i in ('sc query %srvname%') do set "zt=%%i" &goto :next :next if /i "%zt%"=="RUNNING" ( :服务运行正常,返回1. e

zabbix -- 自定义key

为什么要自定义KEY?有时候我们想让被监控端执行一个zabbix没有预定义的检测,zabbix的用户自定义参数功能提供了这个方法.我们可以在客户端配置文件zabbix_angentd.conf里面配置UserParameter. UserParameter=key,command   #语法 用户自定义参数包含一个key和一个命令,key必须整个系统唯一,配置好之后,重启客户端. 然后配置item,在key的位置填上我们自定义的key即可 #命令示例 UserParameter=ping,ech

zabbix自定义key

客户端操作: zabbix 客户端的启动 ./zabbix_agentd -c /usr/local/etc/zabbix_agentd.conf 添加自定义key vi /usr/local/etc/zabbix_agentd.conf 将UnsafeUserParameters从0设置为1,默认是0,即默认自定义key功能是关闭的 在末行添加 UserParameter=io.read,iostat |grep "\<vda\>"|awk '{print $3}' 保存

zabbix 自定义key的简单使用

zabbix版本:zabbix-3.0.2 zabbix客户端配置: zabbix的监控类型分为server和server active(不确定用哪个适合,可以都选择) 在zabbix_agentd.conf中Hostname一定要填写,而且不能和其他监控服务器重复. 自定义key之前需要先设置个参数:UnsafeUserParameters=1 Include=/usr/local/zabbix/etc/zabbix_agentd.conf.d/ # Include=/usr/local/et

Zabbix自定义key监控docker

一.需求场景在某些docker容器中运行着java,容器提供API供监控调用.需要监控服务运行是否正常和容器内JVM使用情况. 二.想法编写监控脚本,使用自定义key的方式添加到Zabbix中. 三.实践1.编写服务监控脚本 #!/bin/bash interval_time=600 service_port_file=/script/tmp/service_port.txt #Gener_service_port tee > ${service_port_file} << EOF ap

zabbix 自定义key 监控mysql增删查改

1.先熟悉一下zabb自定义key的使用格式 vim /etc/zabbix/zabbix_agentd.d/mysql.conf##zabbix_agentd.d在这个文件夹下的.conf,都会被agent读取,我们这里新建的一个配置文件方便使用,这样就不需要去动主配置文件了 UserParameter=echo[*],echo "$1" #要传递参数要带[*],且key键必须全局唯一 UserParameter=ifconfig,ifconfig|awk NR==2'{print

zabbix 自定义key值监控

1.zabbix一般监控使用zabbix即可,如果自定义的监控的话也是可以的,现看下zabbix.agentd.conf里面的介绍 UnsafeUserParameters 默认参数是0,0表示不启用UserParameter,1表示启用. 2. UserParameter=<key>,<shell command> 这个就是自定义监控的命令,key加上监控的选项,如下监控http的连接数 3.改完配置以后一定要重启下,之后再服务端测试下 这里可以看到有输出的,但是没访问所以很少

zabbix自定义key监控mysql主从同步超简单!

1.在zabbix客户端配置文件中加入: 首先要对mysql提供一个查询主从状态的账号!(当然用root也可以.) UserParameter=mysql.replicate_error,if test `mysql -uxxx -pxxx -h127.0.0.1 -e 'show slave status\G' | awk -F: '{if($1~/Slave_IO_Running/) print$2}' ` = "Yes" -a `mysql -uxxx -pxxx -h127.0

zabbix 自定义key监控redis

一.环境 ubuntu 14.04 LTS zabbix 2.4.5 redis-2.8.7 二.配置redis监控 1.在/etc/zabbix/zabbix_agentd.d/目录下新建userparameter_redis.conf文件,添加以下内容: UserParameter=redis.stat[*],cat /tmp/redisstat | grep "$1:" | cut -d":" -f2 2.在/etc/crontab文件下添加以下内容 sudo