前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Redis-脚本-获取某个前缀的key

Redis-脚本-获取某个前缀的key

作者头像
用户5522200
发布2019-06-02 15:23:44
3.2K0
发布2019-06-02 15:23:44
举报
文章被收录于专栏:lindalinda

1.背景

在平时的维护中,经常会遇到要统计某个前缀的key有多少,在请求比较多的redis中,keys * 会直接导致阻塞。 可以采用scan的方式进行增量迭代,查询使用pipeline减少交互,提高效率。

2.scan命令的优缺点

优点: 提供键空间的遍历操作,支持游标,复杂度O(1), 整体遍历一遍只需要O(N); 提供结果模式匹配; 支持一次返回的数据条数设置,但仅仅是个hints,有时候返回的会多; 弱状态,所有状态只需要客户端需要维护一个游标; 缺点: 无法提供完整的快照遍历,也就是中间如果有数据修改,可能有些涉及改动的数据遍历不到; 每次返回的数据条数不一定,极度依赖内部实现; 返回的数据可能有重复,应用层必须能够处理重入逻辑;

3. python脚本的实现

python中有一个封装的函数scan_iter--查看所有元素--迭代器 脚本内容:

代码语言:javascript
复制
#!/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)
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.背景
  • 2.scan命令的优缺点
  • 3. python脚本的实现
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档