当前位置: 首页 > news >正文

Springboot 在 redis 中使用 Guava 布隆过滤器机制

一、导入SpringBoot依赖

pom.xml文件中,引入Spring Boot和Redis相关依赖

<!-- Google Guava 使用google的guava布隆过滤器实现--><dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId><version>30.1-jre</version></dependency>

二、配置布隆过滤器

创建一个布隆过滤器配置类BloomFilterConfig:

import com.google.common.hash.BloomFilter;
import com.google.common.hash.Funnels;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
public class BloomFilterConfig {@Beanpublic BloomFilter<String> bloomFilter() {return BloomFilter.create(Funnels.stringFunnel(Charset.defaultCharset()), 1000000, 0.01);}
}

三、实现缓存服务

创建一个BloomFilterController。使用布隆过滤器判断数据是否存在,从而避免缓存穿透:

package com.springboot3.test;import com.google.common.hash.BloomFilter;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;@RestController
@Controller
public class BloomFilterController {@Autowiredprivate BloomFilter bloomFilter;@Autowiredprivate RedisTemplate redisTemplate;@GetMapping("/cache/{key}")public String getCacheValue(@PathVariable String key) {boolean result = bloomFilter.mightContain(key);if(result==true){Object obj = redisTemplate.opsForValue().get(key);return obj.toString();}return "Cache miss, and the key does not exist in database.";}@GetMapping("/cache/{key}/{value}")public String setCacheValue(@PathVariable String key, @PathVariable String value) {bloomFilter.put(key);return "Cache set successfully.";}}

四、测试

向里面添加元素

 获取元素

http://www.lryc.cn/news/125856.html

相关文章:

  • Docker本地镜像发布到阿里云
  • Postgresql源码(112)plpgsql执行sql时变量何时替换为值
  • OhemCrossEntropyLoss
  • prometheusalert区分告警到不同钉钉群
  • AUTOSAR规范与ECU软件开发(实践篇)3.2 ETAS AUTOSAR系统解决方案介绍(上)
  • 【leetcode】第三章 哈希表part02
  • 【C语言】memset()函数
  • C++中重载(overload)、重写(override,也叫做“覆盖”)和重定义(redefine,也叫作“隐藏”)的区别?
  • 将非受信数据作为参数传入,可能引起xml 注入,引起数据覆盖,这个问题咋解决
  • 设计模式-简单工厂模式
  • Maven框架SpringBootWeb简单入门
  • 关于2023年8月19日PMP认证考试准考信下载通知
  • html实现iphone同款开关
  • 使用Vue和jsmind如何实现思维导图的历史版本控制和撤销/重做功能?
  • 【Vue-Router】路由元信息
  • vue 控件的四个角设置 父视图position:relative
  • VM中linux虚拟机配置桥接模式(虚拟机与宿主机网络互通)
  • 7.Eclipse中改变编码方式及解决部分乱码问题
  • grafana 的 ws websocket 连接不上的解决方式
  • 多环境_部署项目
  • go web框架 gin-gonic源码解读02————router
  • 【Java后端封装数据】常见后端封装数据的格式,用于返回给前端使用(109)
  • 无脑入门pytorch系列(三)—— nn.Linear
  • SQL Server用sql语句添加列,添加列注释
  • springBoot中service层查询使用多线程CompletableFuture(有返回值)
  • 畜牧虚拟仿真 | 鱼授精过程VR模拟演练系统
  • 第一百一十四回 局部动态列表
  • 多尺度目标检测【动手学深度学习】
  • elasticsearch 基础
  • 【BUG】docker安装nacos,浏览器却无法访问到页面