首頁  >  文章  >  後端開發  >  Redis取得某個前綴的key腳本實例

Redis取得某個前綴的key腳本實例

不言
不言原創
2018-05-18 15:28:264152瀏覽

這篇文章主要給大家介紹了關於Redis獲取某個前綴的key腳本的相關資料,文中透過範例程式碼介紹的非常詳細,對大家學習或使用Redis具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。

1.背景

在平常的維護中,常常會遇到要統計某個前綴的key有多少,在請求比較多的redis中,keys * 會直接導致阻斷。
可以採用scan的方式進行漸進式迭代,查詢使用pipeline減少交互,提高效率。

2.scan指令的優缺點

#SCAN指令的有SCAN,SSCAN,HSCAN,ZSCAN。

SCAN的話就是遍歷所有的keys

其他的SCAN指令的話是SCAN選取的集合。

SCAN指令是增量的循環,每次呼叫只會傳回一小部分的元素。所以不會有KEYS指令的坑。

SCAN指令回傳的是一個遊標,從0開始遍歷,到0結束遍歷。

scan 0
1) "655"
2) 1) "test1"
  2) "test2"

傳回值一個array,一個是下次迴圈的cursorId,一個是元素陣列。 SCAN指令不能保證每次回傳的值都是有順序的,另外同一個key有可能回傳多次,不做區分,需要應用程式去處理。

另外SCAN指令可以指定COUNT,預設是10。但這並不是指定多少,就能回傳多少,這只是一個提示,並不能保證一定會回傳這麼多條。

優點:

  • 提供鍵空間的遍歷操作,支援遊標,複雜度O(1), 整體遍歷一遍只需要O(N);

  • 提供結果模式匹配;

  • 支持一次返回的資料條數設置,但僅僅是個hints,有時候回傳的會多;

  • 弱狀態,所有狀態只需要客戶端需要維護一個遊標;

缺點:

  • 無法提供完整的快照遍歷,也就是中間如果有資料修改,可能有些涉及改動的資料遍歷不到;

  • 每次傳回的資料條數不一定,極度依賴內部實作;

  • 傳回的資料可能有重複,應用層必須能夠處理重入邏輯;

3. python腳本的實作

#python中有一個封裝的函數scan_iter--檢視所有元素- -迭代器

腳本內容:

#!/usr/bin/env python
# -*- coding: UTF-8 -*- 
#作用:统计某个前缀key的个数,并将其输入到文件
#使用方法: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]
#每次匹配数量
count = sys.argv[2]
#print match
#print count
#总数量
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 的数量为:%d " % (match,total)

#相關推薦:

##php 使用redis 的快取實例

以上是Redis取得某個前綴的key腳本實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn