Redis获取某个前缀的key脚本实例
在平时的维护中,经常会遇到要统计某个前缀的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)
本篇文章到此结束,如果您有相关技术方面疑问可以联系我们技术人员远程解决,感谢大家支持本站!
我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题
本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 Redis获取某个前缀的key脚本实例
相关文章
- 手把手教你使用Redis停止命令行操作(redis停止命令行)
- 虚拟机搭建桌面环境搭建Redis服务实战(虚拟机 桌面redis)
- 简易步骤如何获取Redis服务器ID(获取redis服务器id)
- 一步步获取Redis库中数据量的实现(获取redis库的数量)
- 从Redis获取参数列表一步一步搞定(获取redis参数列表)
- Vue用Redis储存获取数据(vue获取redis)
- 深入探索 Redis 记录数的获取方式(如何获得redis记录数)
- 掌握Redis地址简单步骤教程(如何获取redis地址)
- 商城利用Redis获取统计信息(商城redis 统计)
- 极速获取Redis数据怎样掌握其中秘密(取redis数据类型)
- 一步步搭建Redis集群 利用分槽优化性能(redis集群分槽)
- 利用Redis集合检索超值信息(redis集合获取值)
- 谁将先于竞争者取得弹性Redis队列抢占之权(redis队列抢占)
- 之间的联系Redis重启信号量的守护作用(redis 重启信号量)
- 利用Redis获取指定范围的数据(redis返回某个范围)
- 设置适当的Redis过期时间关键策略(redis 过期时间策略)
- 有效利用Redis有效利用指南如何获取最大回报(redis 该如何)
- 利用Redis设置密码 实现安全访问(redis设置密码的用途)
- Redis在数据持久化中扮演重要角色(redis 表名)
- 的key利用Redis快速获取指定前缀的键值对(redis获取指定前缀)
- Redis实现获取唯一值方法(redis 获取唯一值)