扣减库存出现锁表情况

在库存扣减过程中,由于查询条件无索引,导致锁表现象,尤其是在秒杀场景下,用户请求超时。解决方案是利用Redis进行库存控制,降低DB压力。问题源于事务中调用第三方接口及在Repeatable Read隔离级别下无索引的查询导致的间隙锁。
摘要由CSDN通过智能技术生成

1. 锁表情景:查询条件没有索引时

​ 库存表中,扣库存时的where条件居然不是id而是奖品类型,而刚好是用事务控制的,微信红包还得调用微信发奖,导致锁表(间隙锁),并且这锁住的时间还是很严重的,每次都得等第三方接口调用成功处理完后续逻辑后,事务才会结束,秒杀场景下就导致了大部分用户超时失败的情况了,以下就是复现了当时的情景

​ 总结起来就是两个严重问题:

  1. 扣库存时没走索引
  2. 在事务中,调第三方接口
create table gap(
	 id int,
	 age int,
	 primary key(id)
)

select * from gap;
INSERT INTO `test`.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值