课程名称:PHP秒杀设计
课程章节:秒杀系统需求分析
课程讲师:皮奇
课程内容:
秒杀系统核心实现
怎样去设计?
- 满足基本需求,做到单服务极致性能。
- 请求链路流量优化,从客户端到服务端每层优化
- 稳定性建设
基本需求是什么
- 扣库存
- 查库存
- 排队进度
- 查订单详情、创建订单、支付订单
基本需求 - 场景假设
这是比较极端的情况,一般情况下不会这样
- 某件商品有1000库存
- 100w并发读
- 100w并发抢购
扣库存方案
- 下单减库存
- 流程:并发请求 -> 创建订单 -> 扣库存 -> 支付
- 优点:不会出现超卖的情况
- 缺点:如果有人恶意下单,库存就没有了,并且也没有实际卖出去
- 流程:并发请求 -> 创建订单 -> 支付 -> 扣库存
- 优点:如果有人下单不支付,也不影响库存
- 缺点:如果有人下单后不支付,在支付前有超过库存数量的人下单,就出现超卖的情况了
- 流程:并发请求 -> 扣库存 -> 创建订单 -> 支付(10分钟内不知道就取消订单,同时恢复扣的这个库存)
- 优点:不会出现超卖,如果有人下单不支付,10分钟后订单会自动关闭,库存会自动恢复
- 流程:并发请求 -> 创建订单 -> 扣库存 -> 支付