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

诸暨公司做网站免费域名注册方式

诸暨公司做网站,免费域名注册方式,教做家常菜的视频网站,节约化网站群建设情况Redis 布隆过滤器解决缓存穿透问题 1. Redis 布隆过滤器解决缓存穿透问题 📌 什么是缓存穿透? 缓存穿透指的是查询的数据既不在缓存,也不在数据库,导致每次查询都直接访问数据库,增加数据库压力。 例如&#xff1…

Redis + 布隆过滤器解决缓存穿透问题

1. Redis + 布隆过滤器解决缓存穿透问题

📌 什么是缓存穿透?

缓存穿透指的是查询的数据既不在缓存,也不在数据库,导致每次查询都直接访问数据库,增加数据库压力。
例如:攻击者故意请求不存在的 ID,导致大量无效查询,冲垮数据库。

解决方案

  • 普通缓存机制:数据库查询为空时,写入一个短期过期的空值,但对高并发请求不够高效。

  • 布隆过滤器方案

    (推荐):

    1. 布隆过滤器预存已有数据的 key
    2. 查询前,先通过布隆过滤器判断 key 是否可能存在:
      • 存在 → 查询 Redis 缓存,未命中则查询数据库,再写入缓存。
      • 不存在 → 直接返回,避免访问数据库,防止缓存穿透。

2. Java 代码示例:Redis + 布隆过滤器

📌 依赖

使用 Redisson 库来操作 Redis 的布隆过滤器,需要添加以下依赖(使用 MavenGradle)。

<dependency><groupId>org.redisson</groupId><artifactId>redisson</artifactId><version>3.21.1</version>
</dependency>

📌 代码示例

🚀 1. 初始化 Redis 连接
import org.redisson.Redisson;
import org.redisson.api.RBloomFilter;
import org.redisson.api.RedissonClient;
import org.redisson.config.Config;public class RedisBloomFilter {private static RedissonClient redissonClient;private static RBloomFilter<String> bloomFilter;static {// 配置 Redis 连接Config config = new Config();config.useSingleServer().setAddress("redis://127.0.0.1:6379"); // 连接本地 RedisredissonClient = Redisson.create(config);// 初始化布隆过滤器bloomFilter = redissonClient.getBloomFilter("product_bloom_filter");bloomFilter.tryInit(1000000L, 0.01); // 预估 100w 个元素,误判率 1%}/*** 向布隆过滤器添加数据*/public static void addToBloomFilter(String productId) {bloomFilter.add(productId);}/*** 判断数据是否可能存在*/public static boolean mightContain(String productId) {return bloomFilter.contains(productId);}public static void main(String[] args) {// 模拟初始化布隆过滤器addToBloomFilter("1001");addToBloomFilter("1002");addToBloomFilter("1003");// 查询数据System.out.println("1001 存在?" + mightContain("1001")); // trueSystem.out.println("2001 存在?" + mightContain("2001")); // false}
}

🚀 2. 结合 Redis 缓存 + MySQL 数据库

import org.redisson.api.RBloomFilter;
import org.redisson.api.RedissonClient;
import redis.clients.jedis.Jedis;public class BloomFilterCacheDemo {private static Jedis redisClient = new Jedis("127.0.0.1", 6379);private static RedissonClient redissonClient;private static RBloomFilter<String> bloomFilter;static {// 配置 Redisson 连接 RedisredissonClient = Redisson.create();bloomFilter = redissonClient.getBloomFilter("product_bloom_filter");bloomFilter.tryInit(1000000L, 0.01); // 100w 数据,误判率 1%}/*** 模拟查询数据库*/public static String queryDatabase(String productId) {if ("1001".equals(productId)) {return "商品1001:iPhone 15";} else if ("1002".equals(productId)) {return "商品1002:MacBook Pro";}return null; // 模拟数据库查询不到}/*** 查询商品详情(使用布隆过滤器+Redis缓存)*/public static String getProductInfo(String productId) {// 1️⃣ 先查询布隆过滤器if (!bloomFilter.contains(productId)) {return "商品不存在"; // 直接返回,防止缓存穿透}// 2️⃣ 查询 Redis 缓存String cacheData = redisClient.get("product:" + productId);if (cacheData != null) {return "【缓存】" + cacheData;}// 3️⃣ 查询数据库String dbData = queryDatabase(productId);if (dbData != null) {// 写入 Redis,设置 10 分钟过期redisClient.setex("product:" + productId, 600, dbData);return "【数据库】" + dbData;}return "商品不存在";}public static void main(String[] args) {// 初始化布隆过滤器(模拟数据库已有商品)bloomFilter.add("1001");bloomFilter.add("1002");// 测试查询System.out.println(getProductInfo("1001")); // 【数据库】商品1001:iPhone 15System.out.println(getProductInfo("2001")); // 商品不存在}
}

3. 运行结果

查询商品 IDRedis 缓存数据库布隆过滤器返回结果
1001❌ 无✅ 有✅ 可能存在【数据库】商品1001:iPhone 15
1001(第二次查询)✅ 有-✅ 可能存在【缓存】商品1001:iPhone 15
2001(不存在)❌ 无❌ 无❌ 一定不存在商品不存在

4. 关键点总结

布隆过滤器防止缓存穿透

  • 先用布隆过滤器检查,如果 不在过滤器内,直接返回,避免查询数据库。

Redis 作为缓存

  • 查询时,优先访问 Redis,如果缓存未命中,才访问数据库,并写入 Redis 进行缓存。

误判率低

  • 通过 bloomFilter.tryInit(1000000L, 0.01),设置合理的 n(数据量)和 p(误判率),确保高效过滤。

不能删除数据

  • 布隆过滤器不支持删除,可以用定期重建的方式优化,例如每天重新初始化。

5. 适用场景

🔹 电商系统:防止查询不存在的商品 ID,减少数据库压力。
🔹 用户系统:防止查询不存在的用户 ID,避免账号碰撞攻击。
🔹 API 限流:判断 IP 或 Token 是否在黑名单,快速拒绝非法请求。

http://www.dtcms.com/a/452511.html

相关文章:

  • 网站建设费用选网络专业大气蓝色企业网站模板
  • 在iis搭建网站pac网站代理
  • 网站关键词快速优化北京交易中心网站
  • 福州网站建设搭建临安市住房和建设局网站
  • 有没有做试题的网站漳州城乡建设局网站首页
  • wordpress 多站点 主题网站建设 博贤科技
  • 福建省龙岩市新罗区建设局网站php做的网站模板下载地址
  • 做旅游的网站那个便宜榆次做企业网站
  • 在线生成个人网站免费观看photoshop安卓版
  • 企业手机网站建设效果做网站ui设计多少钱
  • 淘宝网站是谁做的好个人做的好的淘宝客网站
  • 山东省中国建设银行网站网站团队
  • 企业网站排名要怎么做网站与网页
  • 适用于建设微型网站小程序制作工具
  • 网站建设作业过程微网站免费平台
  • 网站空间数据自己做网站推广关键词
  • 江苏建设造价信息网站青岛网站设计微动力
  • 建设网站教程视频视频家教网站建设的推广
  • 深圳有几个区 分别叫什么seo方案怎么做
  • 做图标的网站南宁网站搜索引擎优化
  • 案例 网站兰州网站制作公司100
  • 韩国建设部网站导游网站后台
  • 网站建设费用什么意思恩施州建设局网站
  • asp.net网站安装顺序中国移动网站建设怎么做
  • 电子商务公司网站设计哪个网站做视频有钱挣
  • 网站建设与管理自考本建站行业发展前景
  • 做360效果图网站wordpress自动发布文章待审
  • 做a网站一个网站大概多少钱
  • 大连学校网站建设wordpress微信分享网页带图
  • 织梦建设网站需要什么软件星辰云二级域名分发