百万级redis key如何模糊查找-scan、scan和keys的区别
创始人
2025-01-15 18:37:12
0


1、KEY*

模糊查询导致交互速度慢、阻塞其他 Redis 操作,在Redis中,使用通配符 KEYS 命令进行键的模糊匹配(比如 KEYS key*)可能会导致性能问题,尤其是在数据集较大时。这是因为 KEYS 命令的实现需要遍历所有的键来匹配模式。

在大规模的生产环境中,遍历所有键可能会导致阻塞其他 Redis 操作,因为 KEYS 命令会持有数据库的写锁。此外,这也可能对性能产生负面影响,因为它需要消耗大量的计算资源。在 Redis 中,所有命令都是按顺序执行的,一个命令执行完成后,才会执行下一个命令。这个单线程模型是 Redis 的设计选择之一,有助于简化并发控制,提高数据一致性。
 

2、scan 迭代模糊查询

在使用redis的时候,我们经常涉及到这样的需求:模糊搜索key,即找出满足特定匹配模式的所有key。但是,如果使用像keys和hkyes这样的方法的话,当key的数量特别多时,效率会很慢,而且对线上的redis查询影响较大,非常不推荐这样的做法。
!!!因为redis是单线程的,所以keys会阻塞其他的操作!!!
比较好的方法是scan这样的方法:
scan:对所有数据类型的key生效;
sscan:针对Set数据类型的key;
hscan:针对Hash的key;
zscan:针对有序Set的key。
scan可以当成一种带有cursor(游标、下标)的迭代器,即每次scan之后,都会返回一个cursor,下次的scan基于上次扫描结束的位置继续扫描。

scan的缺点:

  1. 如果在我们使用scan遍历的过程中,redis新增key的话,可能会出现未捕捉到的情况;
  2. scan有一定的概率会重复返回相同的key,这需要我们在客户端进行去重。

带匹配模式和count的scan

通过设置MATCH,来设计特定的匹配模式,基于glob-style pattern
通过设置COUNT,规定每次scan的数量,默认为10(查到的数据可能会多,可能会少)

 

 

相关内容

热门资讯

无独有偶!哈糖大菠萝万能挂,来... 大家好,今天小编来为大家解答哈糖大菠萝万能挂这个问题咨询软件客服可以免费测试直接加微信(136704...
现有关情况通报如下!多乐够级辅... 现有关情况通报如下!多乐够级辅助软件,杭州边锋辅助软件,大纲教程(其实是真的有挂)-哔哩哔哩;无需打...
现有说明如下!拱趴游戏破解器,... 现有说明如下!拱趴游戏破解器,wpk插件辅助,大纲教程(一贯透视是有挂的)-哔哩哔哩>>您好:软件加...
在玩家背景下!约局吧辅助器下载... 您好:约局吧辅助器下载这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌...
日前!德普软件,wepoker... 大家好,今天小编来为大家解答wepoker私人局透视方法这个问题咨询软件客服可以免费测试直接加微信(...
一直以来!蜀友会通用辅助器,超... 一直以来!蜀友会通用辅助器,超圣大厅可控是什么意思,步骤教程(果然真的有挂的)-哔哩哔哩 >>您好:...
最终!wepoker透视有没有... 最终!wepoker透视有没有,来玩app 德州 辅助,烘培教程(其实透视确实有挂)-哔哩哔哩;无需...
截至目前!哈糖大菠萝诀窍,四川... 截至目前!哈糖大菠萝诀窍,四川家园辅助器,指南书教程(其实确实是有挂)-哔哩哔哩;无需打开直接搜索加...
据统计!hhpoker透视脚本... 据统计!hhpoker透视脚本,wejoker手机版透视脚本,方案教程(其实透视确实有挂)-哔哩哔哩...
今年以来!新众亿免费辅助,微友... 今年以来!新众亿免费辅助,微友联盟辅助,攻略教程(果然是有挂)-哔哩哔哩;无需打开直接搜索加(薇:1...