【Redis】实现异步秒杀功能

一、将判断条件提前缓存到redis中

将判断条件缓存到redis中,如果判断成功直接操作redis中的数据,然后将数据写入redis,如果成功返回一个值。然后根据这个值判断是否成功,如果成功把用户id,优惠卷id,订单id存入阻塞队列中,开启新线程将阻塞队列的数据与数据库进行异步操作查询下单等操作,提供效率。

进行秒杀业务优化的思路就是,先进行判断返回结果。至于后面的操作把需要的信息加入阻塞队列,然后把阻塞队列里的信息异步交给别的线程操作。不过基于内存保存订单信息,如果宕机了,redis中存的数据丢失,后端异步操作的信息还没存入数据库,会有数据不一致问题。可以用消息队列进行操作,这样它会有持久化机制,即使内存中数据丢失,硬盘的数据还会存在。

相关推荐
总爱写点小BUG2 小时前
打印不同的三角形(C语言)
java·c语言·算法
星辰烈龙2 小时前
黑马程序员Java基础9
java·开发语言
山沐与山2 小时前
【Redis】Redis集群模式架构详解
java·redis·架构
amao99882 小时前
数据库--dataset design
数据库
ss2732 小时前
Java并发编程:DelayQueue延迟订单系统
java·python·算法
wcy_10112 小时前
七大软件设计原则
java·设计规范
invicinble2 小时前
jar包在执行的时候需要关注的细节(提供一个解构jvm问题的视角)
java·jvm·jar
麦芽糖02192 小时前
SSE介绍及使用(Server-Send Events)
java
alan07212 小时前
【Java + Elasticsearch全量 & 增量同步实战】
java·elasticsearch·jenkins
hashiqimiya3 小时前
后端springboot的接收前端发来的数据反序列化原理
java