为了账号安全,请及时绑定邮箱和手机立即绑定

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

标签:
PHP

课程名称:PHP秒杀设计

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

课程讲师:皮奇

课程内容:

扣库存分布式实现方案

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

代码实现思路

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

课程收获

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

图片描述

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消