三个 insert 导致的死锁问题

锁种类

  • 插入意向锁(insert intention lock)
  • 对已有数据行的修改与删除,必须加强互斥锁 X 锁,那对于数据的插入,是否还需要加这么强的锁,来实施互斥呢?插入意向锁,孕育而生。
  • 插入意向锁是间隙锁(Gap Locks)的一种,它是专门针对 insert 操作的,也是为数不多的在 RC 级别下产生 Gap 锁情况

锁兼容性

排他锁 X排他意向锁 IX共享锁 S共享意向锁 IS
排他锁 X冲突冲突冲突冲突
排他意向锁 IX冲突兼容冲突兼容
共享锁 S冲突冲突兼容兼容
共享意向锁 IS冲突兼容兼容兼容

查看事务的隔离级别:

select @@global.transaction_isolation;
避免并发操作同一个有唯一约束的值
- 若是单实例(客户端单个主机服务)内出现,可以通过go的内存锁来避免并发同一行
- 若是实例间并发,可通过redis来实现分布式锁,从而避免并发同一行

三个并发导致insert

CREATE TABLE `t` (
  `id` int NOT NULL,
  `c` int DEFAULT NULL,
  `d` int DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `c` (`c`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci

复现步骤

事务一事务二事务三
insert into t values(6,6,6); 持有IX锁
持有X记录锁insert into t values(6,6,6);(block)持IX锁,等待持有S记录锁
insert into t values(6,6,6);(block)持有IX,等待持有S记录锁
begin/rollback 释放IX、X锁持有S记录锁,准备升级成X锁,与事务三的S记录锁冲突持有S记录锁,准备升级成X锁,与事务二的S记录锁冲突
deadlock

上述的操作结果如下:一个 insert 成功,另一个死锁退出

操作如下

事务1 :

事务2:

ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transaction

事务3:

结果

参考资料

  • https://blog.csdn.net/sinat_41780498/article/details/111995067
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wangxiaoming

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值