zabbix 自定义监控项 【userparameter.conf】

1、在装有agent客户端的服务器上的在指定的路径上编写脚本,下图(zabbix_agent2.conf 部分截图)为配置路径位置

2、编写 userparameter.conf 配置文件

 vi /etc/zabbix/zabbix_agent2.d/userparameter.conf

【自定义监控获取Redis缓存中keys的总个数】

UserParameter=redis.keys.count[*], /program/zabbix/command/monitorRedis.py $1 $2  2>/dev/null

  UserParameter= 这个为固定的,后面的内容以逗号隔开

   其中第一个参数为 监控项名字【key】, 如果需要额外的输入参数,则添加[*]

   第二个参数为执行的脚本,$1代表外部输入的第一个参数,$2代表外部输入的第二个参数,依此类推

3、zabbix服务器上添加配置,创建item

主要配置在 *Key, 其中自己配置的不能从Select得到,直接在输入框录入

redis.keys.count["{$redis.hostIp}","{$redis.port}",]

中括号里的值为参数,使用逗号隔开参数,参数可以在宏里面定义,然后使用{$}获取,如下图定义

 备注: 下面图为示意图,本次样例直接写死,没有写在宏里面http://note.youdao.com/yws/public/resource/cc56fa5d302b8a871ba5b21d17881db6/xmlnote/494BF49650094BE39E85612DB8FD49CB/A8BE0A2EA4FC4E7E8817F4878EB46071/808

参数与第一个步骤的外部输入参数相呼应。

注:上面脚本的输出内容为监控项的输出内容,监控Redis 缓存的 key 值 为如下代码

vi  monitorRedis.py

#!/bin/python3
import redis
import sys

#建立数据库连接池、redis连接
pool = redis.ConnectionPool(host = sys.argv[1], port= sys.argv[2], db=0)
rd = redis.Redis(connection_pool=pool)
try :
    keys = rd.keys()
    keyCount = (len(rd.keys()))
    print(keyCount)
except Exception as e:
    print("获取key失败")
finally:
    rd.close()

# host='223.100.128.250', port=16379

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值