首页 > 其他 > 详细

秒杀系统防止库存超卖

时间:2018-06-07 12:44:45      阅读:406      评论:0      收藏:0      [点我收藏+]

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

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("商品已售罄");
}
}
}

秒杀系统防止库存超卖

原文:https://www.cnblogs.com/yxlblogs/p/9149825.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!