zoukankan      html  css  js  c++  java
  • 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()
  • 相关阅读:
    缓存
    mybatis(ibatis)理解
    hibernate理解
    linux vi 命令
    Activity中ConfigChanges属性的用法
    sendStickyBroadcast和sendStickyOrderedBroadcast
    广播 BroadCastReceiver
    Android四大基本组件介绍与生命周期
    ubuntu14.04 开机自动运行应用程序
    Android中BindService方式使用的理解
  • 原文地址:https://www.cnblogs.com/sunkedong/p/7580834.html
Copyright © 2011-2022 走看看