
今天研究一下亿级流量的电商网站是怎么扣减库存
参考自:浅析「扣减库存」的方案设计
本文旨在阐述生产环境如何在高并发的场景下可靠地扣减库存,有其他解决方案的伙伴可以在评论中分享出来。
常规的支付链路是下单->创建订单->支付
用户下单时减库存
优点:实时扣减库存,避免支付时因库存不足减库存的问题
缺点:恶意买家大量下单,但不付款,导致真正想买的人买不到
下单时不会立即减库存,而是等到支付时才会减库存
优点:防止恶意买家大量下用光库存,避免下单扣库存的缺点
缺点:下单页面不是最新的库存,假如支付的订单数超过库存数,则支付失败
下单后预扣库存,超过一定时间后,库存释放。若超过时间后再支付,如果没有库存,则支付失败
优点:实时减库存,缓解恶意买家大量下单的问题,超过一定时间未支付则释放库存
缺点:在一定时间内,恶意买家大量下单仍可以将库存用完。
在库存方面有恶意买家下单占用库存的问题,也会有恶意买家下单后拒付的问题,这种拒付会提高卖家收款账号被风控的概率。因此无论是在库存方面还是在支付方面,都需要解决恶意买家下单的问题
优点:限制恶意买家下单
缺点:非恶意买家会被限制下单,销量会降低
通过历史订单的情况、买家设备指纹(user_agent等),来标识恶意买家。缺点是可能存在误标。
update t_sku_inventory set inventory = inventory + quantity where id = xxx;流程图如下图所示:
