1.背景
在平時的維護中,經(jīng)常會遇到要統(tǒng)計某個前綴的key有多少,在請求比較多的redis/305362.html">redis中,keys * 會直接導致阻塞。
可以采用scan的方式進行增量迭代,查詢使用pipeline減少交互,提高效率。
2.scan命令的優(yōu)缺點
SCAN命令的有SCAN,SSCAN,HSCAN,ZSCAN。
SCAN的話就是遍歷所有的keys
其他的SCAN命令的話是SCAN選中的集合。
SCAN命令是增量的循環(huán),每次調(diào)用只會返回一小部分的元素。所以不會有KEYS命令的坑。
SCAN命令返回的是一個游標,從0開始遍歷,到0結(jié)束遍歷。
scan 01) "655"2) 1) "test1" 2) "test2"
返回值一個array,一個是下次循環(huán)的cursorId,一個是元素數(shù)組。SCAN命令不能保證每次返回的值都是有序的,另外同一個key有可能返回多次,不做區(qū)分,需要應用程序去處理。
另外SCAN命令可以指定COUNT,默認是10。但是這個并不是指定多少,就能返回多少,這只是一個提示,并不能保證一定返回這么多條。
優(yōu)點:
缺點:
3. python腳本的實現(xiàn)
python中有一個封裝的函數(shù)scan_iter--查看所有元素--迭代器
腳本內(nèi)容:
#!/usr/bin/env python# -*- coding: UTF-8 -*- #作用:統(tǒng)計某個前綴key的個數(shù),并將其輸入到文件#使用方法:python scan_redis.py apus* 100__author__ = "lcl" import sysimport redis import os pool=redis.ConnectionPool(host='192.168.225.128',port=6379,db=0) r = redis.StrictRedis(connection_pool=pool) #掃描匹配值,通過sys.argv傳參match = sys.argv[1]#每次匹配數(shù)量count = sys.argv[2]#print match#print count#總數(shù)量total = 0#掃描到的key輸出到文件path = os.getcwd()#掃描到的key輸出的文件txt = path+"/keys.txt"f = open(txt,"w")for key in r.scan_iter(match = match,count = count):# f.write("%s %s" % (key,"/n")) f.write(key+"/n") total = total+1f.closeprint "匹配: %s 的數(shù)量為:%d " % (match,total)
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網(wǎng)的支持。
新聞熱點
疑難解答
圖片精選