標籤:應該 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指令碼