【Redis】实现异步秒杀功能

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

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

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

相关推荐
麦聪聊数据12 小时前
数据服务化时代:企业数据能力输出的核心路径
数据库
飞天狗11112 小时前
零基础JavaWeb入门——第五课第二小节:九大内置对象 · 第2个:response(响应对象)
java·开发语言
许彰午12 小时前
39_Java单元测试JUnit入门
java·junit·单元测试
shushangyun_12 小时前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
JAVA96512 小时前
JAVA面试-JVM篇 03-JVM运行时数据区哪些是线程私有的哪些是共享的
java·jvm·面试
于先生吖13 小时前
教育类Java实战项目:在线错题整理平台分层架构设计与接口源码解析
java·开发语言
DARLING Zero two♡13 小时前
【MySQL数据库】数据类型与表约束
数据库·mysql
慧一居士13 小时前
Feign的GET请求如何传递对象参数?
java·spring cloud
曹牧13 小时前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon13 小时前
SQL学习指南——视图
数据库·sql