热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

zabbix监控redispython3脚本

一:安装redis-python模块wgethttps:pypi.python.orgpackagessourcerredisredis-2.9.1.tar.gztarxfr
一:安装redis-python模块 

wge  thttps://pypi.python.org/packages/source/r/redis/redis-2.9.1.tar.gz 

tar xf redis-2.9.1.tar.gz 

cd redis-2.9.1 

python setup.py install

 

二:配置zabbix 

(1) 将zabbix-redis.py 放入到/usr/local/zabbix/etc/scripts目录下 

(2) 更改zabbix_agentd.conf include${dir}/zabbix.UserParameter 

(3) 重启zabbix_agentd 

killall zabbix_agentd 

/usr/local/zabbix/sbin/zabbix_agentd -c/usr/local/zabbix/etc/zabbix_agentd.conf

 

二:主要的监控项目包括 

客户端查询key值命中数和未命中数,可计算出命中率 

当前redis实例的客户端连接数 

当前处于阻塞状态下的客户端数量 

客户端每秒执行命令的频率 

连接从库的数量 

内存使用状况

 

三:具体参数解释 

keyspace_misses //表示未命中数 

keyspace_hits //表示命中数 

keyspace_hits_rate = keyspace_hits /(keyspace_hits + keyspace_misses)

connected_clients //客户端连接数 

blocked_clients //客户端阻塞数 

connected_slaves //从库数

instantaneous_ops_per_sec //客户端每秒执行命令频率

 

used_memory_rss //操作系统分配给redis的内存 

used_memory //redis分配器分配的内存 

mem_fragmentation_ratio //内存碎片比例 在理想情况下, 

used_memory_rss 的值应该只比 used_memory 稍微高一点儿。当rss > used ,且两者的值相差较大时,表示存在(内部或外部的)内存碎片。 当used > rss时,表示Redis的部分内存被操作系统换出到交换空间了,在这种情况下,操作可能会产生明显的延迟。

 

 

四.监控脚本

1、python2获取reis的脚本

#!/bin/python
#
-*- coding:UTF-8 -*-
#
author sunkedong Mail: 512378102@qq.com QQ: 512378103
import redis
import sys


"""
各个参数的解释:
keyspace_misses //表示未命中数
keyspace_hits //表示命中数
keyspace_hits_rate = keyspace_hits /(keyspace_hits + keyspace_misses)
connected_clients //客户端连接数
blocked_clients //客户端阻塞数
connected_slaves //从库数
instantaneous_ops_per_sec //客户端每秒执行命令频率
used_memory_rss //操作系统分配给redis的内存
used_memory //redis分配器分配的内存
mem_fragmentation_ratio //内存碎片比例
"""
#把参数定义为列表
keyindex = ['used_memory', 'used_memory_rss', 'mem_fragmentation_ratio', 'blocked_clients', 'connected_clients',
'connected_slaves',
'instantaneous_ops_per_sec', 'keyspace_hits', 'keyspace_misses', 'keypace_query_total_count',
'keyspace_hits_rate', 'status']

returnval
= None
def zabbix_faild():
print "ZBX_NOTSUPPORTED"
sys.exit(
2)
if len(sys.argv) != 2: #需要有一个参数,加上程序本身是两个参数。所以判断如果没有参数,就直接提示
print len(sys.argv)
zabbix_faild()

try:
conn
=redis.Redis(host='172.16.17.40',port='6379',password='')
except Exception,e:
print e
zabbix_faild()


#下面是根据参数来判断并且取值,最终返回状态,加入到zabbix中
if sys.argv[1] in keyindex:
if sys.argv[1] == 'status':#如果参数为status ,执行ping,为true返回值为1,zabbix中返回1 则表示正常。
try:
conn.ping()
returnval
= 1
except Exception,e:
returnval
= 0
elif sys.argv[1] == 'keyspace_hits_rate':
merit
= conn.info()
keyspace_hits_count
= float(merit['keyspace_hits'])
keyspace_misses_count
= float(merit['keyspace_misses'])
keyspace_hits_rate
= keyspace_hits_count / (keyspace_hits_count + keyspace_misses_count) * 100
returnval
= keyspace_hits_rate
elif sys.argv[1] == 'keypace_query_total_count':
merit
= conn.info()
keyspace_hits_count
= merit['keyspace_hits']
keyspace_misses_count
= merit['keyspace_misses']
keypace_query_total_count
= keyspace_hits_count + keyspace_misses_count
returnval
= keypace_query_total_count
else:
merit
= conn.info()
try:
returnval
= merit[unicode(sys.argv[1])]
except Exception,e:
pass

#判断返回值状态的函数
def ret_status ():
if returnval == None:
zabbix_faild()
else:
print returnval

ret_status()

 

2、python3获取redis 的脚本

#!/usr/bin/python
#
-*- coding:UTF-8 -*-
import redis
import sys

"""
各个参数的解释:
keyspace_misses //表示未命中数
keyspace_hits //表示命中数
keyspace_hits_rate = keyspace_hits /(keyspace_hits + keyspace_misses)
connected_clients //客户端连接数
blocked_clients //客户端阻塞数
connected_slaves //从库数
instantaneous_ops_per_sec //客户端每秒执行命令频率
used_memory_rss //操作系统分配给redis的内存
used_memory //redis分配器分配的内存
mem_fragmentation_ratio //内存碎片比例
"""
#把参数定义为列表
keyindex = ['used_memory', 'used_memory_rss', 'mem_fragmentation_ratio', 'blocked_clients', 'connected_clients',
'connected_slaves',
'instantaneous_ops_per_sec', 'keyspace_hits', 'keyspace_misses', 'keypace_query_total_count',
'keyspace_hits_rate', 'status']

returnval
= None
def zabbix_faild():
print("ZBX_NOTSUPPORTED")
sys.exit(
2)
if len(sys.argv) != 2: #需要有一个参数,加上程序本身是两个参数。所以判断如果没有参数,就直接提示
zabbix_faild()

try:
conn
=redis.Redis(host='192.168.40.36',port='6379',password='123456')
#这个是python的语法,和python3有些不一样
#
except Exception,e:
#
zabbix_faild()
except Exception as e:
zabbix_faild()

#下面是根据参数来判断并且取值,最终返回状态,加入到zabbix中
if sys.argv[1] in keyindex:
if sys.argv[1] == 'status':#如果参数为status ,执行ping,为true返回值为1,zabbix中返回1 则表示正常。
try:
conn.ping()
returnval
= 1
except Exception as e:
returnval
= 0
elif sys.argv[1] == 'keyspace_hits_rate':
merit
= conn.info()
keyspace_hits_count
= float(merit['keyspace_hits'])
keyspace_misses_count
= float(merit['keyspace_misses'])
keyspace_hits_rate
= keyspace_hits_count / (keyspace_hits_count + keyspace_misses_count) * 100
returnval
= keyspace_hits_rate
elif sys.argv[1] == 'keypace_query_total_count':
merit
= conn.info()
keyspace_hits_count
= merit['keyspace_hits']
keyspace_misses_count
= merit['keyspace_misses']
keypace_query_total_count
= keyspace_hits_count + keyspace_misses_count
returnval
= keypace_query_total_count
#python3 不需要unicode
# else:
# merit = conn.info()
# try:
# returnval = merit[unicode(sys.argv[1])]
# except Exception as e:
# pass
else:
merit
= conn.info()
try:
returnval
= merit[(sys.argv[1])]
except Exception as e:
pass

#判断返回值状态的函数
def ret_status ():
if returnval == None:
zabbix_faild()
else:
print(returnval)
ret_status()

 


推荐阅读
  • 在Kubernetes上部署JupyterHub的步骤和实验依赖
    本文介绍了在Kubernetes上部署JupyterHub的步骤和实验所需的依赖,包括安装Docker和K8s,使用kubeadm进行安装,以及更新下载的镜像等。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • 本文介绍了在Linux下安装Perl的步骤,并提供了一个简单的Perl程序示例。同时,还展示了运行该程序的结果。 ... [详细]
  • 本文介绍了三种方法来实现在Win7系统中显示桌面的快捷方式,包括使用任务栏快速启动栏、运行命令和自己创建快捷方式的方法。具体操作步骤详细说明,并提供了保存图标的路径,方便以后使用。 ... [详细]
  • 成功安装Sabayon Linux在thinkpad X60上的经验分享
    本文分享了作者在国庆期间在thinkpad X60上成功安装Sabayon Linux的经验。通过修改CHOST和执行emerge命令,作者顺利完成了安装过程。Sabayon Linux是一个基于Gentoo Linux的发行版,可以将电脑快速转变为一个功能强大的系统。除了作为一个live DVD使用外,Sabayon Linux还可以被安装在硬盘上,方便用户使用。 ... [详细]
  • Windows 7 部署工具DISM学习(二)添加补丁的步骤详解
    本文详细介绍了在Windows 7系统中使用部署工具DISM添加补丁的步骤。首先需要将光驱中的安装文件复制到指定文件夹,并进行挂载。然后将需要的MSU补丁解压并集成到系统中。文章给出了具体的命令和操作步骤,帮助读者完成补丁的添加过程。 ... [详细]
  • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
  • 基于dlib的人脸68特征点提取(眨眼张嘴检测)python版本
    文章目录引言开发环境和库流程设计张嘴和闭眼的检测引言(1)利用Dlib官方训练好的模型“shape_predictor_68_face_landmarks.dat”进行68个点标定 ... [详细]
author-avatar
隐姓埋名er
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有