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

2022/9/29 4:16:23

本文主要是介绍【九月打卡】第21天 PHP秒杀设计之扣库存分布式实现方案,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

课程名称:PHP秒杀设计

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

课程讲师:皮奇

课程内容:

扣库存分布式实现方案

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

代码实现思路

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

课程收获

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

图片描述



这篇关于【九月打卡】第21天 PHP秒杀设计之扣库存分布式实现方案的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程