课程名称:PHP秒杀设计
课程章节:扣库存分布式实现方案
课程讲师:皮奇
课程内容:
扣库存分布式实现方案
并发量过大极致单服务还是扛不住怎么办?
- 可以把库存分摊到多台机器上,假如总库存为1000,共10台机器,可以给每台机器分摊100库存,请求通过负载均衡来选择要到那一台机器来处理
- 这种方案通过把总库存分摊到每台机器的本地来减小单服务器的压力
本地减库存,集群集群挂了怎么办?怎么保证不少卖?
- 给每台机器多分摊一些库存,再增加一个“统一减库存”的服务,每台机器在本地减完库存以后再调用统一减库存的服务
- 假设共1000库存,10台机器,可以给每台机器分130的库存,这样就多出来了300库存,这种情况下可以允许有3台左右的机器出现故障
代码实现思路
- 初始化库存到本地库存
- 本地减库存,成功则进行统一减库存,失败则返回
- 统一减库存成功则写入MQ,异步创建订单
- 告知用户抢购成功
课程收获
温故而知新,高并发秒杀也不似猛虎般的难了,学习到了新的知识
点击查看更多内容
为 TA 点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦