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: 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()

 

转载于:https://www.cnblogs.com/sunkedong/p/7580834.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的Python3脚本,用于监控Redis服务器的状态。它使用redis-py库与Redis服务器进行交互,并将结果发送到Zabbix服务器。 ```python #!/usr/bin/env python3 import redis import sys import time from pyzabbix import ZabbixMetric, ZabbixSender # Redis服务器的IP地址和端口号 REDIS_HOST = '127.0.0.1' REDIS_PORT = 6379 # Zabbix服务器的IP地址和端口号 ZABBIX_HOST = '127.0.0.1' ZABBIX_PORT = 10051 # 获取Redis服务器的状态信息 def get_redis_stats(): r = redis.StrictRedis(host=REDIS_HOST, port=REDIS_PORT) info = r.info() uptime = info['uptime_in_seconds'] used_memory = info['used_memory'] max_memory = info['maxmemory'] used_cpu_sys = info['used_cpu_sys'] used_cpu_user = info['used_cpu_user'] return (uptime, used_memory, max_memory, used_cpu_sys, used_cpu_user) # 将状态信息发送到Zabbix服务器 def send_to_zabbix(metrics): sender = ZabbixSender(ZABBIX_HOST, ZABBIX_PORT) result = sender.send(metrics) return result # 主函数 def main(): while True: # 获取Redis服务器的状态信息 (uptime, used_memory, max_memory, used_cpu_sys, used_cpu_user) = get_redis_stats() # 将状态信息打包成ZabbixMetric对象 metrics = [ ZabbixMetric('redis.server', 'uptime', uptime), ZabbixMetric('redis.server', 'used_memory', used_memory), ZabbixMetric('redis.server', 'max_memory', max_memory), ZabbixMetric('redis.server', 'used_cpu_sys', used_cpu_sys), ZabbixMetric('redis.server', 'used_cpu_user', used_cpu_user), ] # 发送状态信息到Zabbix服务器 send_to_zabbix(metrics) # 等待一段时间 time.sleep(60) if __name__ == '__main__': main() ``` 这个脚本会每60秒获取一次Redis服务器的状态信息,并将其发送到Zabbix服务器。它将状态信息打包成ZabbixMetric对象,并使用pyzabbix库将其发送到Zabbix服务器。您可以在Zabbix服务器上创建一个名为redis.server的主机,并将这些指标添加到该主机的监视项中。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值