秒杀优化—基于 Redis 完成秒杀下单

目标:把秒杀核心逻辑搬到 Redis 层,用 Lua 脚本实现"库存扣减 + 防一人多单"一体化,降低数据库压力。

图片把"异步秒杀"拆成两段:Redis + Lua 做极速判断,后台队列做慢速落库,基于 Redis 完成秒杀下单核心思路。

  1. 入口只做快速校验(Lua 脚本)
  • 先判断库存字段 stock:vid:7 是否大于 0(不足直接返回 1)。
  • 再判断用户 ID 是否已经在 order:vid:7 集合里(已下单返回 2)。
  • 只有同时满足"库存足够、用户未下单"时,才在脚本里原子扣减库存并把用户 ID 加入集合,最后返回 0 表示"通过"。

2.接口立即返回,主流程很快

  • 业务线程拿到 Lua 返回值:0 → 说明抢购成功,可以生成订单任务;非 0 → 直接给用户提示"库存不足"或"已抢过"。
  • 整个过程都在 Redis 内存完成,O(1) 速度,不访问数据库,接口可以承受高并发。

3.异步落库(削峰填谷)

  • 当 Lua 返回 0 时,并不是立刻去数据库扣库存、写订单,而是把"优惠券ID + 用户ID + 预生成的订单ID"塞入阻塞队列或消息队列。
  • 后台消费者线程按队列顺序慢慢处理:真正创建订单、持久化到数据库。这样数据库压力被平滑摊开,避免瞬时崩溃。

因此,基于 Redis 完成秒杀下单的异步秒杀思路就是:

"入口少做事(Redis + Lua 原子校验)、请求线程秒回;重活交给后台队列处理,实现削峰填谷,既防止超卖也保护数据库"。

相关推荐
AllData公司负责人4 分钟前
【亲测好用】实时开发平台能力演示
java·c语言·数据库
fengxin_rou28 分钟前
Redis从零到精通第二篇:redis常见的命令
数据库·redis·缓存
多多*30 分钟前
Mysql数据库相关 事务 MVCC与锁的爱恨情仇 锁的层次架构 InnoDB锁分析
java·数据库·windows·sql·oracle·面试·哈希算法
大数据在线30 分钟前
技术的终极善意:抹平集中式和分布式边界
数据库·信创·pingcap·国产数据库·平凯数据库
晓131335 分钟前
第六章:Redis分布式缓存
redis·nosql
Henry Zhu12344 分钟前
数据库(三):关系代数
数据库
历程里程碑1 小时前
Linux 16 环境变量
linux·运维·服务器·开发语言·数据库·c++·笔记
流㶡1 小时前
mysql学习笔记之创建表、导入导出数据
数据库·mysql
Monkey的自我迭代1 小时前
实战项目数据桥agent复盘
数据库·python·oracle
赵锦川1 小时前
Oracle数据库序列的创建
数据库