答:一般来说,我们接触最多的是使用 keys 来进行查询,keys 使用的话也比较简单,但是在正式环境中话必须禁止使用 keys, 而是推荐使用 scan.
keys 的使用
语法:keys PATTERN:用于查找所有符合给定模式 PATTERN 的 key
keys * # 查询 redis 中所有的 key
keys h?llo # ?: 通配单个字符, 可以是 hello hallo ..., 不包含 hllo.
keys h*llo # * 通配任意多个字符, hllo hello heello heallo ...
keys h[ae]llo # []: 通配括号内的某一个字符,可以查询出 hello hallo, 不可以查出 hllo.
keys h[^e]llo # 匹配 e 之前的字母, 可以是 hallo ... hdllo ,不包含 hello.
keys h[a-b]llo # - 相当于 or, 匹配 a 或 b, 可以是 hallo hbllo; 可以添加更多的条件,比如: keys h[a-b-c-d]llo
# 上面的语法还可以进行相应的组合,如
keys h[a-b]*llo # 匹配 ha(任意多个字符)llo 和 hb(任意多个字符)llo
正式环境禁用keys的原因
keys 的时间复杂度为:O(N), 其中N为数据库中密钥的数目,假设数据库中的密钥名称和给定模式的长度有限。尽管其复杂的为 O(N), 但是持续的时间却很短,在一个入门级别的电脑上可以做到 40ms 扫描 100 万个数据。
但是如果是高并发的条件下,使用 keys 就会出现问题,因为 Redis 是一个单线程的数据库,每次执行命令都会对数据库进行加锁&#x