Redis SCAN命令
1. 获取指定前缀的key
需求描述:
Redis中有大量以xxx开头的key,在不使用keys命令的情况下,如何快速获取这些前缀的key
解决方案:
redis自带的scan命令可以解决这个问题
2. SCAN命令
SCAN是一个基于游标的迭代器。这意味着在每次调用该命令时,服务器都会返回一个更新后的游标,用户需要在下一次调用中使用它作为游标参数。当游标设置为0时开始迭代,当服务器返回的游标为0时终止迭代。从游标值为0开始迭代,并调用SCAN直到返回的游标再次为0,这称为完整迭代。
时间复杂度:每次调用 O(1)。O(N) 用于完整的迭代,包括足够的命令调用以使光标返回 0。N 是集合内的元素数。
和scan命令相关的还有另外3个命令,分别是:
- SCAN 迭代当前选定的Redis数据库中的一组键
- SSCAN 迭代 Sets 类型的元素
- HSCAN 迭代 Hash 类型的字段及其相关值
- ZSCAN 迭代 Sorted Set 类型的元素及其相关分数
语法:
SCAN cursor [MATCH pattern] [COUNT count] [TYPE type]
选项:
MATCH选项
和KEYS命令类似,后面可以跟一个通配符
COUNT选项
SCAN不能保证每次迭代返回的元素数量,但可以使用COUNT选项根据经验调整SCAN的行为。基本上,使用COUNT,用户指定了每次调用时从集合中检索元素所需完成的工作量。这只是实现的一个提示,但是一般来说,但是在大多数情况下,这种提示都是有效的(在数据量少的情况下,COUNT值与返回的结果数量不相等)。
TYPE选项
可以使用 TYPE 选项要求 SCAN 仅返回与给定类型匹配的对象。 TYPE 选项仅在整个数据库 SCAN 上可用,而不是 HSCAN 或 ZSCAN 等。