手记

【九月打卡】第21天 PHP秒杀设计之扣库存分布式实现方案

课程名称:PHP秒杀设计

课程章节:扣库存分布式实现方案

课程讲师:皮奇

课程内容:

扣库存分布式实现方案

并发量过大极致单服务还是扛不住怎么办?
  • 可以把库存分摊到多台机器上,假如总库存为1000,共10台机器,可以给每台机器分摊100库存,请求通过负载均衡来选择要到那一台机器来处理
  • 这种方案通过把总库存分摊到每台机器的本地来减小单服务器的压力
本地减库存,集群集群挂了怎么办?怎么保证不少卖?
  • 给每台机器多分摊一些库存,再增加一个“统一减库存”的服务,每台机器在本地减完库存以后再调用统一减库存的服务
  • 假设共1000库存,10台机器,可以给每台机器分130的库存,这样就多出来了300库存,这种情况下可以允许有3台左右的机器出现故障

代码实现思路

  • 初始化库存到本地库存
  • 本地减库存,成功则进行统一减库存,失败则返回
  • 统一减库存成功则写入MQ,异步创建订单
  • 告知用户抢购成功

课程收获

温故而知新,高并发秒杀也不似猛虎般的难了,学习到了新的知识

0人推荐
随时随地看视频
慕课网APP