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

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 针对 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());

   }

}

运行结果


相关文章
|
1月前
|
NoSQL Java 网络安全
SpringBoot启动时连接Redis报错:ERR This instance has cluster support disabled - 如何解决?
通过以上步骤一般可以解决由于配置不匹配造成的连接错误。在调试问题时,一定要确保服务端和客户端的Redis配置保持同步一致。这能够确保SpringBoot应用顺利连接到正确配置的Redis服务,无论是单机模式还是集群模式。
204 5
|
2月前
|
NoSQL Java 调度
分布式锁与分布式锁使用 Redis 和 Spring Boot 进行调度锁(不带 ShedLock)
分布式锁是分布式系统中用于同步多节点访问共享资源的机制,防止并发操作带来的冲突。本文介绍了基于Spring Boot和Redis实现分布式锁的技术方案,涵盖锁的获取与释放、Redis配置、服务调度及多实例运行等内容,通过Docker Compose搭建环境,验证了锁的有效性与互斥特性。
211 0
分布式锁与分布式锁使用 Redis 和 Spring Boot 进行调度锁(不带 ShedLock)
|
8月前
|
NoSQL Java 关系型数据库
微服务——SpringBoot使用归纳——Spring Boot 中集成Redis——Redis 介绍
本文介绍在 Spring Boot 中集成 Redis 的方法。Redis 是一种支持多种数据结构的非关系型数据库(NoSQL),具备高并发、高性能和灵活扩展的特点,适用于缓存、实时数据分析等场景。其数据以键值对形式存储,支持字符串、哈希、列表、集合等类型。通过将 Redis 与 Mysql 集群结合使用,可实现数据同步,提升系统稳定性。例如,在网站架构中优先从 Redis 获取数据,故障时回退至 Mysql,确保服务不中断。
342 0
微服务——SpringBoot使用归纳——Spring Boot 中集成Redis——Redis 介绍
|
8月前
|
缓存 NoSQL Java
基于SpringBoot的Redis开发实战教程
Redis在Spring Boot中的应用非常广泛,其高性能和灵活性使其成为构建高效分布式系统的理想选择。通过深入理解本文的内容,您可以更好地利用Redis的特性,为应用程序提供高效的缓存和消息处理能力。
768 79
|
5月前
|
机器学习/深度学习 数据采集 人机交互
springboot+redis互联网医院智能导诊系统源码,基于医疗大模型、知识图谱、人机交互方式实现
智能导诊系统基于医疗大模型、知识图谱与人机交互技术,解决患者“知症不知病”“挂错号”等问题。通过多模态交互(语音、文字、图片等)收集病情信息,结合医学知识图谱和深度推理,实现精准的科室推荐和分级诊疗引导。系统支持基于规则模板和数据模型两种开发原理:前者依赖人工设定症状-科室规则,后者通过机器学习或深度学习分析问诊数据。其特点包括快速病情收集、智能病症关联推理、最佳就医推荐、分级导流以及与院内平台联动,提升患者就诊效率和服务体验。技术架构采用 SpringBoot+Redis+MyBatis Plus+MySQL+RocketMQ,确保高效稳定运行。
422 0
|
8月前
|
存储 人工智能 NoSQL
SpringBoot整合Redis、ApacheSolr和SpringSession
本文介绍了如何使用SpringBoot整合Redis、ApacheSolr和SpringSession。SpringBoot以其便捷的配置方式受到开发者青睐,通过引入对应的starter依赖,可轻松实现功能整合。对于Redis,可通过配置RedisSentinel实现高可用;SpringSession则提供集群Session管理,支持多种存储方式如Redis;整合ApacheSolr时,借助Zookeeper搭建SolrCloud提高可用性。文中详细说明了各组件的配置步骤与代码示例,方便开发者快速上手。
167 11
|
8月前
|
NoSQL Java API
微服务——SpringBoot使用归纳——Spring Boot 中集成Redis——Spring Boot 集成 Redis
本文介绍了在Spring Boot中集成Redis的方法,包括依赖导入、Redis配置及常用API的使用。通过导入`spring-boot-starter-data-redis`依赖和配置`application.yml`文件,可轻松实现Redis集成。文中详细讲解了StringRedisTemplate的使用,适用于字符串操作,并结合FastJSON将实体类转换为JSON存储。还展示了Redis的string、hash和list类型的操作示例。最后总结了Redis在缓存和高并发场景中的应用价值,并提供课程源代码下载链接。
2016 0
|
8月前
|
NoSQL Java Redis
微服务——SpringBoot使用归纳——Spring Boot 中集成Redis——Redis 安装
本教程介绍在 VMware 虚拟机(CentOS 7)或阿里云服务器中安装 Redis 的过程,包括安装 gcc 编译环境、下载 Redis(官网或 wget)、解压安装、修改配置文件(如 bind、daemonize、requirepass 等设置)、启动 Redis 服务及测试客户端连接。通过 set 和 get 命令验证安装是否成功。适用于初学者快速上手 Redis 部署。
238 0
|
存储 SQL 消息中间件
springboot整合redis
redis是一个支持key-value的数据库,数据全部在内存中处理,在在一定时间间隔中将数据固化到磁盘。因为是内存操作,所以速度特别快。(这里我们主要介绍redis作为缓存使用)
306 0
springboot整合redis
|
存储 缓存 NoSQL
SpringBoot整合Redis
SpringBoot整合Redis
574 0
SpringBoot整合Redis

热门文章

最新文章