Redis如何获取某个前缀的key脚本

36次阅读
没有评论

共计 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 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计1495字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)