MySQL 死锁 是指两个或多个事务互相等待对方持有的锁,从而导致所有事务都无法继续执行的现象。在 InnoDB 存储引擎中,死锁是通过锁机制产生的,特别是在并发较高、业务逻辑复杂的情况下,更容易发生死锁。
一、MySQL 死锁的成因
MySQL 的死锁一般发生在 行级锁 上。常见的死锁成因包括:
- 事务 A 和事务 B 持有互相需要的锁:事务 A 锁住了记录 1,事务 B 锁住了记录 2,事务 A 尝试获取记录 2 的锁,而事务 B 试图获取记录 1 的锁,造成了死锁。
- 不同顺序的锁定:两个事务对同一组资源请求加锁,但是加锁顺序不同,导致互相等待。例如,事务 A 按照顺序锁定记录 1 和记录 2,而事务 B 以相反的顺序锁定记录 2 和记录 1。
- 使用了 gap lock (间隙锁):在 InnoDB 的 Next-Key Locking 机制下,间隙锁定也可能导致死锁,尤其是在范围查询时,多个事务试图锁定同一间隙。
- 长事务和锁等待时间过长:事务执行时间长,未及时释放锁,造成其他事务等待锁超时或死锁。
二、死锁检测与处理
MySQL 使用 死锁检测 来处理死锁问题。MySQL 会自动检测事务是否处于死锁状态,并中止其中一个事务,释放锁以允许另一个事务继
订阅专栏 解锁全文
1451

被折叠的 条评论
为什么被折叠?



