【Redis】实现异步秒杀功能

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

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

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

相关推荐
m***92385 小时前
【SQL】MySQL中的字符串处理函数:concat 函数拼接字符串,COALESCE函数处理NULL字符串
数据库·sql·mysql
20岁30年经验的码农5 小时前
Java Elasticsearch 实战指南
java·开发语言·elasticsearch
okseekw5 小时前
Java 中的注释与关键字的初步学习
java
luv_sw5 小时前
JavaSE-面向对象-构造器
java
okseekw5 小时前
Java 中的类型转换:结合实战代码深入解析
java
!停5 小时前
VS实用调试技巧
数据库
CoderYanger5 小时前
优选算法-优先级队列(堆):75.数据流中的第K大元素
java·开发语言·算法·leetcode·职场和发展·1024程序员节
luv_sw5 小时前
JavaSE-面向对象-抽象类和接口
java
TracyCoder1236 小时前
MySQL 实战宝典(八):Java后端MySQL分库分表工具解析与选型秘籍
java·开发语言·mysql
wasp5206 小时前
做了技术管理后,我发现技术和管理其实可以兼得
java·运维·网络