支付宝是如何解决热点库存扣减问题的?

支付宝是如何解决热点库存扣减问题的?

https://mp.weixin.qq.com/s/4XQAdXEVIjXnicauPE-yMw

典型问题: 热点库存扣减

这个是典型的秒杀场景,秒杀系统相对简单的库存扣减问题,比如春节红包雨活动,同一个资金池子有数亿人抢红包,比如阿里巴巴针对红包活动150万QPS的峰值压力,应该如何设计库存扣减方案呢?

常规方案

采用分桶设计,将库存均匀分发到 N 个 Redis 分桶中。通过 Incr 无锁的方式,高效扣减库存。

  1. 假设 key 失效了怎么办?
  2. 假设 Incr 方法失效了怎么办,

上面两种情况都会满足 $num < $max

复制代码
$num = $redis->incr($key);
if ($num > 0 && $num < $max) { 
 //入抢购成功队列,异步去执行抢购成功逻辑
} else {
 //不好意思呢,已经被抢完了
}

缺点:

每个桶库存消耗不均,会导致实际还有库存,但是有部分用户无法扣减库存,引发客诉。

优化后的方案

  • 小量多次分派库存,从而缓解消耗不均问题。
  • 21年抖音春节红包,将用户进入的时间打散,减少瞬时请求峰值。
相关推荐
liu****3 分钟前
4.Qt窗口开发全解析:菜单栏、工具栏、状态栏及对话框实战
数据库·c++·qt·系统架构
Python_Study20254 小时前
面向工程材料行业的数据采集系统架构设计与选型指南
系统架构
鱼跃鹰飞10 小时前
面试题:什么是时钟回拨问题?怎么解决
分布式·系统架构
宋康11 小时前
QThread 与 QtConcurrent
数据库·c++·系统架构
智算菩萨14 小时前
【无线通信基础】典型的无线通信系统全解析:从无线寻呼到卫星通信
网络·系统架构
一路往蓝-Anbo1 天前
第 4 篇:策略模式 (Strategy) —— 算法的热插拔艺术
网络·驱动开发·stm32·嵌入式硬件·算法·系统架构·策略模式
AUVpwoxkW2 天前
探索自动避障路径选择:Matlab 路径规划算法与仿真实践
系统架构
RockHopper20252 天前
解读数字化生产运行系统的裁决机制
运维·系统架构·智能制造·isa-95·isa-88
pursue.dreams2 天前
马斯克开源X推荐算法深度解析:Grok驱动的推荐系统架构
系统架构·开源·推荐算法·x
未来龙皇小蓝2 天前
Spring内置常见线程池配置及相关概念
java·后端·spring·系统架构