1. 程式人生 > >zabbix 監控redis python3腳本

zabbix 監控redis python3腳本

.tar.gz 系統 返回 命中率 腳本 mis div 正常 imp

一:安裝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()

zabbix 監控redis python3腳本