Redis 用 scan 替代 keys

本文讨论了在Redis中,由于`keys`命令可能导致服务器阻塞,不适用于生产环境的问题。提出了使用非阻塞的`scan`命令作为替代方案,尽管`scan`存在键可能在迭代过程中被修改的不确定性,但它提供了增量式迭代的保障。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景

先看一下 keys 命令的定义。

KEYS pattern
查找所有符合给定模式 pattern 的 key 。

KEYS * 匹配数据库中所有 key 。
KEYS h?llo 匹配 hello , hallo 和 hxllo 等。
KEYS h*llo 匹配 hllo 和 heeeeello 等。
KEYS h[ae]llo 匹配 hello 和 hallo ,但不匹配 hillo。

但是,当 keys 命令被用于处理一个大的数据库时,它可能会阻塞服务器达数秒之久,从而导致其他 redis 的命令超时,导致系统报错。

因此 keys 命名不适用于生产环境

替代命令 SCAN

先看一下 scan 命令的定义。

SCAN 命令是一个基于游标的迭代器,每次被调用之后, 都会向用户返回一个新的游标, 用户在下次迭代时需要使用这个新游标作为 SCAN 命令的游标参数, 以此来延续之前的迭代过程。
SCAN 返回一个包含两个元素的数组, 第一个元素是用于进行下一次迭代的新游标, 而第二个元素则是一个数组, 这个数组中包含了所有被迭代的元素。如果新游标返回 0 表示迭代已结束。

SCAN cursor [MATCH pattern] [COUNT count]
cursor - 游标。
pattern - 匹配的模式。
count - 指定从数据集里返回多少元素,默认值为 10 。

127.0.0.1:6379> scan 0 MATCH tony* 
1) "42"
2)  1) "tony25"
    2) "tony2519"
    3) "tony2529"
    4) 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值