秒杀系统防止库存超卖

Posted 学亮

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了秒杀系统防止库存超卖相关的知识,希望对你有一定的参考价值。

第一种:通过数据库乐观锁实现(小型电商)

update productstocks set realstock=realstock-#{buys} where sku = #{sku} and realstock-#{buys}>=0

根据受影响的行数判断是否执行成功

大型互联网不是这么玩的
数据库有瓶颈
第二种:使用redis 分布式锁实现

var resource = "the-thing-we-are-locking-on";
var expiry = TimeSpan.FromSeconds(5);
var wait = TimeSpan.FromSeconds(10);
var retry = TimeSpan.FromSeconds(1);
string sku = "001";

using (var redLock = RedisHelper.RedlockFactory.CreateLock(resource, expiry, wait, retry)) // there are also non async Create() methods
{
if (redLock.IsAcquired)
{
var r = RedisHelper.StringGet(sku);
var num = new Random().Next(1, 10);

if (Convert.ToInt32(r) >= num)
{
RedisHelper.StringDecrement(sku, num);
}
else
{
throw new Exception("商品已售罄");
}
}
}

以上是关于秒杀系统防止库存超卖的主要内容,如果未能解决你的问题,请参考以下文章

谈一谈秒杀系统如何设计

如何解决高并发秒杀的超卖问题

秒杀系统如何防止超卖?

秒杀系统秒杀系统之「防止超卖」一

秒杀踩坑记:库存超卖

秒杀系统常见问题—库存超卖