這篇文章主要介紹了redis如何獲取某個前綴的key腳本,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
公司主營業(yè)務(wù):網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出望都免費做網(wǎng)站回饋大家。
1.背景
在平時的維護中,經(jīng)常會遇到要統(tǒng)計某個前綴的key有多少,在請求比較多的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 0 1) "655" 2) 1) "test1" 2) "test2"
返回值一個array,一個是下次循環(huán)的cursorId,一個是元素數(shù)組。SCAN命令不能保證每次返回的值都是有序的,另外同一個key有可能返回多次,不做區(qū)分,需要應(yīng)用程序去處理。
另外SCAN命令可以指定COUNT,默認是10。但是這個并不是指定多少,就能返回多少,這只是一個提示,并不能保證一定返回這么多條。
優(yōu)點:
提供鍵空間的遍歷操作,支持游標,復雜度O(1), 整體遍歷一遍只需要O(N);
提供結(jié)果模式匹配;
支持一次返回的數(shù)據(jù)條數(shù)設(shè)置,但僅僅是個hints,有時候返回的會多;
弱狀態(tài),所有狀態(tài)只需要客戶端需要維護一個游標;
缺點:
無法提供完整的快照遍歷,也就是中間如果有數(shù)據(jù)修改,可能有些涉及改動的數(shù)據(jù)遍歷不到;
每次返回的數(shù)據(jù)條數(shù)不一定,極度依賴內(nèi)部實現(xiàn);
返回的數(shù)據(jù)可能有重復,應(yīng)用層必須能夠處理重入邏輯;
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 sys import 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+1 f.close print "匹配: %s 的數(shù)量為:%d " % (match,total)
感謝你能夠認真閱讀完這篇文章,希望小編分享的“Redis如何獲取某個前綴的key腳本”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識等著你來學習!
文章名稱:Redis如何獲取某個前綴的key腳本
網(wǎng)站網(wǎng)址:http://sd-ha.com/article44/jisoee.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站、企業(yè)網(wǎng)站制作、App開發(fā)、微信公眾號、ChatGPT、網(wǎng)站收錄
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)