1. 死锁产生原因
1、产生原因:
所谓死锁:是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去.此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程。表级锁不会产生死锁.所以解决死锁主要还是针对于最常用的InnoDB。
死锁的关键在于:两个(或以上)的Session加锁的顺序不一致。
那么对应的解决死锁问题的关键就是:让不同的session加锁有次序
ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transaction
2. mysql死锁的解决发方法:
- 1、等待,直到超时(
innodb_lock_wait_timeout
=50s),自动回滚事务; - 2、发起死锁检测,主动回滚一条事务,让其他事务继续执行(
innodb_deadlock_detect
=on)。
3. MySQL有两种死锁处理方式:
● 等待,直到超时(innodb_lock_wait_timeout=50s),自动回滚事务。
● 发起死锁检测,主动回滚一条事务,让其他事务继续执行(innodb_deadlock_detect=on)。
由于性能原因,一般都是使用死锁检测来进行处理死锁。
3.1 . 死锁检测
死锁检测的原理是构建一个以事务为顶点、锁为边的有向图,判断有向图是否存在环,存在即有死锁。
回滚
检测到死锁之后,选择插入更新或者删除的行数最少的事务回滚,基于 INFORMATION_SCHEMA.INNODB_TRX
表中的 trx_weight 字段来判断。