Redis8中的布谷鸟过滤器

前言

Redis8新增布谷鸟过滤器,也是一种概率过滤器,用来判断集合中元素存在与否,跟布隆过滤器差不多,在某些场景下表现还可能优于布隆过滤器

布谷鸟过滤器

新增布谷鸟过滤器

使用CF.RESERVE创建布谷鸟过滤器

css 复制代码
CF.RESERVE key capacity [BUCKETSIZE bucketsize] [MAXITERATIONS maxiterations] [EXPANSION expansion]

key: 过滤器键值

capacity: 过滤器容量

bucketsize: 每个桶中的项目数

MAXITERATIONS: 决定了寻找传入指纹槽位的尝试次数

expansion: 创建新过滤器时,其大小是当前过滤器大小乘以 expansion

创建过滤器

perl 复制代码
CF.RESERVE qq  1000

创建一个名为qq的布谷鸟过滤器

重复创建会报

CF.ADD添加元素

使用

vbnet 复制代码
CF.ADD key item

添加元素

重复添加也可以

CF.ADDNX

CF.ADDNX命令,不存在时,才会添加元素

vbnet 复制代码
CF.ADDNX key item

执行

复制代码
CF.ADDNX aa1 aa1

重复添加键值会报

CF.COUNT

CF.COUNT命令是判断元素添加次数

vbnet 复制代码
CF.COUNT key item

CF.DEL

CF.DEL命令是删除一次元素,对于多次添加的,还是会存在

vbnet 复制代码
CF.DEL key item

执行命令

复制代码
CF.DEL aa aa

再次执行

复制代码
CF.COUNT aa aa

输出结果为

CF.EXISTS

CF.EXISTS是判断元素是否存在

vbnet 复制代码
CF.EXISTS key item

执行命令

复制代码
CF.EXISTS aa aa

输出结果为

找一个没有的元素

CF.MEXISTS

CF.MEXISTS批量判断元素是否存在

css 复制代码
CF.MEXISTS key item [item ...]

执行命令

复制代码
CF.MEXISTS aa aa aa1 aa2

输出结果为

CF.INFO

CF.INFO命令查看布谷鸟过滤器信息

不存在会报错

CF.INSERT

CF.INSERT创建一个布谷鸟过滤器,并添加元素

css 复制代码
CF.INSERT key [CAPACITY capacity] [NOCREATE] ITEMS item [item ...]

执行命令

objectivec 复制代码
CF.INSERT qq CAPACITY 1000 ITEMS  hello hello1 hello2

输出结果为

不存在则会创建

CF.INSERTNX

CF.INSERTNX不存在则添加

css 复制代码
CF.INSERTNX key [CAPACITY capacity] [NOCREATE] ITEMS item [item ...]

执行

objectivec 复制代码
CF.INSERTNX qq1 CAPACITY 1000 ITEMS  hello hello1 hello2 HELLO3

输出结果为

总结

Redis8新增布谷鸟过滤器,现在可以借助Redis工具存,而不用自己写

相关推荐
小兵张健2 小时前
30天减20斤挑战:少一斤发100红包(6)
程序员
Deepincode3 小时前
Redis源码探究系列—跳表(skiplist)源码实现详解
redis
修己xj3 小时前
现实中的程序员:阳台上的黄菖蒲
程序员
古城小栈3 小时前
从 cargo-whero 库中,找到提升 rust 的契机
开发语言·后端·rust
keep one's resolveY4 小时前
SpringBoot实现重试机制的四种方案
java·spring boot·后端
阿丰资源6 小时前
基于Spring Boot的电影城管理系统(直接运行)
java·spring boot·后端
IT_陈寒6 小时前
SpringBoot自动配置的坑差点让我加班到天亮
前端·人工智能·后端
虹科网络安全6 小时前
艾体宝产品|深度解读 Redis 8.4 新增功能:原子化 Slot 迁移(下)
数据库·redis·bootstrap
消失的旧时光-19437 小时前
Spring Boot 工程化进阶:统一返回 + 全局异常 + AOP 通用工具包
java·spring boot·后端·aop·自定义注解
灵机一物7 小时前
灵机一物AI原生电商小程序、PC端(已上线)-【无标Anthropic 研究深度解析:AI 对就业市场的实际冲击与高危职业排行题】
人工智能·ai·程序员·职业发展·anthropic·就业市场