SpringBoot 如何集成 Redis 实现布隆过滤器

本文涉及的产品
云原生内存数据库 Tair,内存型 2GB
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Redis 版,经济版 1GB 1个月
简介: 针对 Redis 的缓存穿透问题,布隆过滤器是一个常见的解决办法。在单机的场景下,我们可以使用谷歌的 guava 包里面提供的布隆过滤器。在分布式的场景下,我们也可以选用 Redis 来实现布隆过滤器。

SpringBoot 如何集成 Redis 实现布隆过滤器

前言

本篇文章的代码示例已放到 github 上,Git地址为:advance(记录每一个学习过程),项目的介绍页面是我所有文章的一个引用目录,大家在引用目录里面即可找到对应文章的一个代码路径。

大家觉得有用的话,麻烦点个star👍再走呗!

使用场景

针对 Redis 的缓存穿透问题,布隆过滤器是一个常见的解决办法。在单机的场景下,我们可以使用谷歌的 guava 包里面提供的布隆过滤器。在分布式的场景下,我们也可以选用 Redis 来实现布隆过滤器。

虽然,Redis 的 BitMap天然就可以作为 布隆过滤器来实现,但毕竟自己实现的话,还是会有点麻烦。因此,我们可以选用 redisson 提供的布隆过滤器,提高我们的开发效率。

常用方法

配置布隆过滤器的Bean

@Bean

public RBloomFilter<String>  bloomFilter(){

   // 定义一个布隆过滤器,指定布隆过滤器的名称

   RBloomFilter<String> bloomFilter = redissonClient.getBloomFilter("bloomTest");

   //定义布隆过滤器的大小,以及误差率

   bloomFilter.tryInit(100000L, 0.003);

   return bloomFilter;

}

获取布隆过滤器

配置完之后,这个布隆过滤器就在 Spring 容器里面了,可以直接注入进来

@Autowired

private RBloomFilter<String> bloomFilter;

添加元素

String name1 = "小明";

String name2 = "小张";

bloomFilter.add(name1);

bloomFilter.add(name2);

判断布隆过滤器中是否存在某元素

boolean flag1 = bloomFilter.contains("小明");

System.out.println("布隆过滤器中是否可能有小明?" + flag1);

获取布隆过滤器的元素总数

System.out.println("当前布隆过滤器中有多少个数?" + bloomFilter.count());

获取布隆过滤器预计可以插入多少个数

System.out.println("预计布隆过滤器中可以插入多少个数?" + bloomFilter.getExpectedInsertions());

获取布隆过滤器的容错率

System.out.println("布隆过滤器的容错率:" + bloomFilter.getFalseProbability());

获取哈希函数的个数

System.out.println("布隆过滤器哈希哈数的个数:" + bloomFilter.getHashIterations());

获取 Bit 位的个数

System.out.println("布隆过滤器的bit位有多少个?" + bloomFilter.getSize());

使用示例

@Component

public class LineRunner implements CommandLineRunner {

   @Autowired

   private RBloomFilter<String> bloomFilter;

   @Override

   public void run(String... args) throws Exception {

       String name1 = "小明";

       String name2 = "小张";

       bloomFilter.add(name1);

       bloomFilter.add(name2);

       boolean flag1 = bloomFilter.contains("小明");

       System.out.println("布隆过滤器中是否可能有小明?" + flag1);

       boolean flag2 = bloomFilter.contains("小李");

       System.out.println("布隆过滤器中是否可能有小李?" + flag2);

       System.out.println("当前布隆过滤器中有多少个数?" + bloomFilter.count());

       System.out.println("预计布隆过滤器中可以插入多少个数?" + bloomFilter.getExpectedInsertions());

       System.out.println("布隆过滤器的容错率:" + bloomFilter.getFalseProbability());

       System.out.println("布隆过滤器哈希哈数的个数:" + bloomFilter.getHashIterations());

       System.out.println("布隆过滤器的bit位有多少个?" + bloomFilter.getSize());

   }

}

运行结果


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
1天前
|
监控 负载均衡 Java
Spring Boot与微服务治理框架的集成
Spring Boot与微服务治理框架的集成
|
1天前
|
负载均衡 Java Nacos
Spring Boot与微服务治理框架的集成策略
Spring Boot与微服务治理框架的集成策略
|
1天前
|
缓存 NoSQL Java
Spring Boot整合Redis缓存的最佳实践
Spring Boot整合Redis缓存的最佳实践
|
2天前
|
存储 NoSQL Java
大事件后端项目34_登录优化----redis_SpringBoot集成redis
大事件后端项目34_登录优化----redis_SpringBoot集成redis
大事件后端项目34_登录优化----redis_SpringBoot集成redis
|
4天前
|
缓存 NoSQL Java
Spring Boot中集成Redis实现缓存功能
Spring Boot中集成Redis实现缓存功能
|
4天前
|
缓存 NoSQL Java
Spring Boot与Redis集成的最佳实践
Spring Boot与Redis集成的最佳实践
|
存储 SQL 消息中间件
springboot整合redis
redis是一个支持key-value的数据库,数据全部在内存中处理,在在一定时间间隔中将数据固化到磁盘。因为是内存操作,所以速度特别快。(这里我们主要介绍redis作为缓存使用)
183 0
springboot整合redis
|
存储 缓存 NoSQL
SpringBoot整合Redis
SpringBoot整合Redis
347 0
SpringBoot整合Redis
|
NoSQL Redis 存储
springboot整合redis
直接上代码吧 1.首先pom中加入 org.springframework.boot spring-boot-starter-web org.
1251 0