zabbix 监控redis python3脚本

一:安装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: [email protected]     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()
时间: 2024-10-10 17:07:14

zabbix 监控redis python3脚本的相关文章

Redis 学习(Zabbix 监控Redis)

前面redis的配置文件盒常用命令.redis info信息都解释完了,接下来就是监控我们的redis了,我使用的是zabbix监控软件,所有在这里我在这里详细介绍下怎么设置zabbix来监控reids,主要分为配置zabbix插件.插件脚本.创建模板监控项.创建图形几个方面. Redis 学习(配置文件和常用命令注释): http://54snow.blog.51cto.com/2690157/1537449 Redis 学习(Redis Info详细注释): http://54snow.bl

Zabbix监控redis配置及宏的使用

本文主要介绍zabbix宏的简单使用,通过自定义脚本监控redis相关指标. zabbix监控redis需要自定义脚本去监控,网络上的脚本对于在一台机器上有多个redis实例不是很实用.于是修改了下监控脚本,使其可以接受传入端口参数. 原理:通过redis客户端连接命令,过滤出info输出的信息 一.zabbix宏介绍及定义 1.宏介绍 (1)宏是一种抽象,他根据一系列预定义的规则替换一定的文本模式,而解释器或编译器在遇到宏时会自动进行这一模式替换,可以理解为变量. (2)zabbix有许多内置

zabbix监控windows日志脚本

zabbix监控windows日志脚本     脚本用于监控windows服务器上日志,查看日志文件的末尾N行,如果N行中包含某字段,则输出0,否则输出1,然后再zabbix的配置文件空定义kye,进行监控. 文本文件的换行符是"\n" 编辑脚本log.py import sys import re def last_lines(filename, lines = 1):     lines = int(lines)     block_size = 1024     block = 

zabbix监控redis、mysql性能、mysql状态、php-fpm性能状态

zabbix监控redis http://www.21yunwei.com/archives/4195 zabbix监控mysql性能 http://www.ttlsa.com/zabbix/zabbix-monitor-mysql/ zabbix监控mysql装态 http://www.linuxidc.com/Linux/2016-04/130436.htm zabbix监控php-fpm性能状态 http://www.ttlsa.com/zabbix/zabbix-monitor-php-

zabbix 监控 redis

通过redis自带的info命令来监控redis的健康状态,通过redis-cli PING命令来监控redis的存活状态. 附件中有监控模板,将监控脚本放在redis服务器的自定义的/scripts/zabbix_redis/下: #! /bin/bash #Name: redismontior.sh REDISCLI="/usr/bin/redis-cli" HOST="127.0.0.1" PORT=6379 if [[ $# == 1 ]];then    

zabbix监控redis DB key的总数量

一个简单监控redis DB的key数量,脚本如下: #!/bin/bash PORT='7010' HOST='192.168.33.33' echo `redis-cli -h ${HOST} -p ${PORT} <<EOF select 1 llen data1 EOF` > /usr/local/redis/script/redix.txt echo `awk '{print $2}' /usr/local/redis/script/redix.txt` exit 0 脚本实现

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

对于多实例部署的tomcat.redis等应用,可以利用zabbix的low level discovery功能来实现监控,减少重复操作. 注:Zabbix版本: Zabbix 3.0.2 一.服务端配置 1.创建模板 模板名称: Template_Redis_Monitor 2.创建自动发现规则 给已创建好的模板Template_Redis_Monitor添加自动发现规则. 3.添加监控项原型 从上面截图可以看到,我已经创建了4个,具体如下: 看看其中一个: 再来看看主机关联模板后的监控项:

Zabbix监控 之sendEmail脚本邮件报警配置【5】

本次zabbix邮件报警时通过sendEmail这一个轻量级的命令行的smtp电子邮件客户端,使用脚本的方式实现邮件报警. 此次使用的Linux发行版是CentOS 6.5,zabbix版本为3.0.3 Zabbix监控之不发送邮件异常[附属] 一.下载sendEmail wget http://caspian.dotconf.net/menu/Software/SendEmail/sendEmail-v1.56.tar.gz sendEmail安装方法: 1 2 3 shell# tar xv

zabbix监控管理维护脚本

zabbix监控的机器越来越多,新增机器很频繁,废弃的,每天都在手动同样的事情,写了个脚本自动维护,已经加入到MySQL初始化安装.机器下线.高可用等流程中,自动处理: 脚本如下: #!/usr/bin/python  #coding:utf-8    import json  import urllib2  from urllib2 import URLError  import sys,argparse   class zabbix_api:  def __init__(self):