Redis从海量Key里查询某一个固定前缀的Key
Redis从海量Key里查询某一个固定前缀的Key
使用 scan cursor [MATCH pattern] [COUNT count]。
- 基于游标的迭代器,需要基于上一次的游标延续之前的迭代过程;
- 以0作为游标开始一次新的迭代,知道命令返回游标0完成一次遍历;
- 不保证每次执行都返回某个给定数量的元素,支持模糊查询;
- 一次返回的数量不可控,只能是大概率符合count参数;
实操
scan 0 match k1* count 10 其含义是开始迭代返回前缀为k1的key,并且希望一次返回10个,scan 为0表示刚开始迭代,执行之后如图。
1)中就是我们的游标,2)就是返回的数值,执行时redis并不会发生卡顿,将新的游标代替0,继续执行 scan 11534336 match k1* count 10,结果如图
此结果可能会是重复的,所以需要我们在代码中利用hashSet去重,这样就可以解决此问题。