码迷,mamicode.com
首页 > 其他好文 > 详细

Zabbix监控redis多实例(low level discovery)

时间:2016-05-03 16:11:17      阅读:379      评论:0      收藏:0      [点我收藏+]

标签:

对于多实例部署的tomcat、redis等应用,可以利用zabbix的low level discovery功能来实现监控,减少重复操作。
 注:Zabbix版本: Zabbix 3.0.2
一、服务端配置
1、创建模板
模板名称: Template_Redis_Monitor
技术分享
 
2、创建自动发现规则
给已创建好的模板Template_Redis_Monitor添加自动发现规则。
技术分享
 
技术分享
 
技术分享
 
3、添加监控项原型
从上面截图可以看到,我已经创建了4个,具体如下:
技术分享
 
看看其中一个:
技术分享
 
再来看看主机关联模板后的监控项:
技术分享
 
二、客户端配置
zabbix_agentd.conf配置文件添加或修改内容如下:
UnsafeUserParameters=1   #允许zabbix用户运行root命令
UserParameter=redis.discovery,/data/zabbix/externalscripts/redis_port.py  #获取json格式数据,上报端口
UserParameter=redis[*],/data/zabbix/externalscripts/redis_stats.sh $1 $2    #自定义Key值

用到的两个脚本内容如下:

发现端口的脚本:

# cat redis_port.py
#!/usr/bin/env python
import os
import json
p=os.popen("""sudo netstat -anp|awk -F: ‘/redis-server/&&/LISTEN/{sub(/ .*/,"",$2);if($2)print $2}‘ """)
ports = []
for port in  p.readlines():
    r = os.path.basename(port.strip())
    ports += [{{#REDISPORT}:r}]
print json.dumps({data:ports},sort_keys=True,indent=4,separators=(,,:))

 获取监控数据的脚本:

# cat redis_stats.sh
#!/bin/bash
METRIC="$1"
PORT="${2:-6379}"
CACHE_FILE="/data/zabbix/externalscripts/redis_$PORT.cache"
redis-cli -p ${PORT} -a USLF93SUVwtSF$$#@W info > ${CACHE_FILE} 2>/dev/null || exit 1
awk -F[:,]+ /‘"${METRIC}"‘:/{gsub(/^[^0-9]+/,"",$2);print $2} ${CACHE_FILE}
三、测试
在zabbix_server上进行测试,执行以下命令:
zabbix_get -s 客户端IP -k redis.discovery

技术分享

客户端redis两个实例端口为6380和6444,可以看到自动发现端口成功!
测试是否可以获取数据:
技术分享
获取数据成功!
最后可以创建图形,查看数据:
技术分享
 
其它问题:zabbix_agentd是zabbix用户启动的,默认不能执行netstat -p等命令,因此可以配置sudo解决。
也可以使用chmod +s /usr/bin/netstat进行解决。

Zabbix监控redis多实例(low level discovery)

标签:

原文地址:http://www.cnblogs.com/Eivll0m/p/5455210.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!