共計 1495 個字符,預計需要花費 4 分鐘才能閱讀完成。
自動寫代碼機器人,免費開通
這篇文章主要介紹了 Redis 如何獲取某個前綴的 key 腳本,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓丸趣 TV 小編帶著大家一起了解一下。
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)
感謝你能夠認真閱讀完這篇文章,希望丸趣 TV 小編分享的“Redis 如何獲取某個前綴的 key 腳本”這篇文章對大家有幫助,同時也希望大家多多支持丸趣 TV,關注丸趣 TV 行業資訊頻道,更多相關知識等著你來學習!
向 AI 問一下細節