黑马点评plus --异步秒杀重构升级

黑马点评plus --异步秒杀重构升级

参考 阿星不是程序员 的开源项目

https://gitee.com/java-up-up/hmdp-plus

前端发起请求

localhost:8085/voucher-order/seckill/{id} , 后端接受一个voucherId 后续seckillVoucher方法执行下单逻辑

java 复制代码
  Result<Long> seckillVoucher(Long voucherId);

整体流程图

查询优惠券信息(by Id)

优惠券信息查询使用多级缓存存储优惠券信息, 双重判断 + 缓存空值 + 分布式锁 + 布隆过滤器 组合的方案来解决缓存击穿和穿透的问题

流程图(gpt生成)

为什么要 两次检查 Redis 缓存 是否命中 ?

  • 防止缓存击穿
  • 避免大量线程同时查数据库

一个线程来到 了 ,去查 本地缓存redis 都没命中 ,就会去查 数据库,但是 此时这个线程, 还没有来得及重写到redis中时,又有一大批线程来了,此时虽然第一个线程已经查到了,但这些线程仍然需要去查数据库 ,这样就造成大量数据库的查询操作 ,影响性能 .

分布式锁+再次判断redis解决 解决缓存击穿

此时 , 一个线程来了 ,去查 本地缓存redis 都没命中, 接着 这个线程会和其他一大批线程竞争分布式锁 ,只有拿到锁的 线程 继续往后走

其他线程等待 ,等这个线程执行结束了 ( 查完数据库 -> 写入缓存), 释放锁 ,其他线程才能继续竞争锁 ,往后执行, 再次判断redis 是否命中 ,命中直接返回,从而 当很多相同的并发查询来到时, 只允许一个线程去数据库查询拿信息再写回缓存(分布式锁), 大大减少了数据库的压力.

到时, 只允许一个线程去数据库查询拿信息再写回缓存(分布式锁), 大大减少了数据库的压力.

注意: 这个在查询优惠券库存时 也用到了

相关推荐
不知名的老吴9 分钟前
线程的生命周期之线程同步
java·开发语言·jvm
协享科技11 分钟前
Spring Boot 与 Go 双服务架构实践:从单体拆分到通信设计
java·人工智能·spring boot·后端·架构·golang·ai编程
码语智行1 小时前
地图上图、空间拓扑查询示例
java·arcgis
程序员黑豆1 小时前
AI全栈开发 - Java:变量
java·前端·ai编程
我是一颗柠檬1 小时前
【Java项目技术亮点】分库分表+数据路由策略:单表5000万后的架构升级方案
java·开发语言·分布式·架构
布朗克1681 小时前
25 IO流高级操作——序列化、NIO与Files工具类
java·数据库·io·nio
小研说技术1 小时前
Spring AI实现rag流程(简易版)
java·后端
亓才孓1 小时前
【本地项目引用外部库的类,想修改字段遇到的请缓存的问题】
java·maven
小林敲代码77882 小时前
记录一下IDEA中很多变量变色的方案
java·开发语言·spring boot·idea
南知意-2 小时前
IDEA 2026.1最新版安装教程
java·ide·intellij-idea·idea安装·idea激活