【redis】scan系列命令详解

scan

常用于在大量redis key中寻找具有指定前缀的key(当然如果你一直使用图形工具可能不太了解它)

它是一个基于游标的迭代器,每次被调用之后, 都会向用户返回一个新的游标, 用户在下次迭代时需要使用这个新游标作为 SCAN 命令的游标参数, 以此来延续之前的迭代过程,初始游标为0。

SCAN 返回一个包含两个元素的数组, 第一个元素是用于进行下一次迭代的新游标, 而第二个元素则是一个数组, 这个数组中包含了所有被迭代的元素。

如果新游标返回 0 表示迭代已结束,即不再又下一页的数据,如果返回数据为空但是游标不为空表示迭代还未结束。

测试数据

set test:1 1     
set test:2 2    
set test:3 3  
set test:4 4   
set test:5 5   
set test:6 6 
set test:7 7
set test:8 8
set test:9 9
set test:10 10
SCAN cursor [MATCH pattern] [COUNT count]

最普通的scan命令

scan 0

扫描全部数据,默认返回count=10

但是这个10并不是准确的返回数据量,10是扫描哈希槽的数量,而不是数据量,这是为了加快查询速度。由于redis string的k-v是以hashmap方式存,可能出现空哈希槽,也可能出现哈希碰撞即一个槽里出现多个数据的情况。

scan 0 match test:* count 5

遍历顺序

scan 的遍历顺序非常特别,它不是从第一维数组的第0位一直遍历到末尾,而是采用了高位进位加法来遍历。这是考虑到字典的扩容和缩容时避免槽位的遍历重复和遗漏。

高位进位法从左边加,进位往右边移动,同普通加法正好相反。但是最终它们都会遍历所有的槽位并且没有重复。

sscan

scan用来遍历集合,命令格式与scan几乎一样,只是多了指定集合名字参数

127.0.0.1:6379> sadd class1 1
127.0.0.1:6379> sadd class1 2
127.0.0.1:6379> sadd class1 3
127.0.0.1:6379> sadd class1 4
127.0.0.1:6379> sadd class1 5
127.0.0.1:6379> sadd class1 6
127.0.0.1:6379> sadd class1 7
127.0.0.1:6379> sadd class1 8
127.0.0.1:6379> sadd class1 9
127.0.0.1:6379> sadd class1 10
127.0.0.1:6379> sadd class1 11
127.0.0.1:6379> sadd class1 abc
127.0.0.1:6379> sadd class1 adds
127.0.0.1:6379> sadd class1 bcc

zscan、hscan

与之类似还有zscan、hscan

当然它们的count都不是特别准确(也是哈希槽数量),但是配合match和游标还是很有用处。

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值