zabbix 監控redis python3指令碼

來源:互聯網
上載者:User

標籤:應該   pytho   blog   nic   cli   pypi   串連數   執行命令   空間   

一:安裝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: 512378103import redisimport 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 = Nonedef 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 returnvalret_status()

 

2、python3擷取redis 的指令碼

#!/usr/bin/python# -*- coding:UTF-8 -*-import redisimport 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 = Nonedef 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指令碼

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.