Mysql死锁以及死锁日志分析

数据库 MySQL
通过阅读死锁日志,我们可以清楚地知道两个事务形成了怎样的循环等待,再加以分析,就可以逆向推断出循环等待的成因,也就是死锁形成的原因。

死锁的概念

死锁:死锁一般是事务相互等待对方资源,***形成环路造成的。

对于死锁,数据库处理方法:牺牲一个连接,保证另外一个连接成功执行。

发生死锁会返回ERROR:1213 错误提示,大部分的死锁InnoDB存储引擎本身可以侦测到,不需要人为进行干预。

注意:

InnoDB存储引擎并不会回滚大部分的错误异常,像阻塞章节里面的例子,但是死锁例外,发现死锁后,InnoDB存储引擎会马上回滚一个事务,会返回1213错误。 

死锁的情形举例

eg1: 

  

  

 

分析死锁日志:

***部分

从日志里我们可以看到事务1当前正在执行update info_users set mobile='18514656666' where mobile='18514656620',该条语句正在申请表info_users的索引IDX_MOBILE的X锁,所以提示lock_mode X waiting

第二部分:

然后日志的下半部分说明了事务2当前‘持有的锁’以及‘等待的锁’:

从日志的HOLDS THE LOCKS(S)块中我们可以看到事务2持有索引IDX_MOBILE的X锁,并且是记录锁(Record Lock)。该锁是通过事务2在步骤2执行的update语句申请的。

从日志的WAITING FOR THIS LOCK TO BE GRANTED块中我们可以看到事务2正在申请持有表info_area的索引GEN_CLUST_INDEX的X锁,该锁是delete from info_area where id=1;语句申请的。

eg2:  

 

eg3: 

  

  

 

分析死锁日志:

***部分

从日志里我们可以看到事务1当前正在执行DELETE from users where uid='bbb';,该条语句正在申请索引UID的X锁,所以提示lock_mode X waiting

第二部分:

然后日志的下半部分说明了事务2当前‘持有的锁’以及‘等待的锁’:

从日志的HOLDS THE LOCKS(S)块中我们可以看到事务2持有索引UID的X锁,并且是记录锁(Record Lock)。该锁是通过事务2在步骤2执行的delete语句申请的。

从日志的WAITING FOR THIS LOCK TO BE GRANTED块中我们可以看到事务2正在申请持有索引UID的S锁,该锁是insert INTO users VALUES(2,'bbb');语句申请的。insert语句在普通情况下是会申请X锁,但是这里出现了S锁。这是因为uid字段是一个唯一索引,所以insert语句会在插入前进行一次duplicate key的检查,为了使这次检查成功,需要申请S锁防止其他事务对uid字段进行修改。

那么为什么该S锁会失败呢?这是对同一个字段的锁的申请是需要排队的。S锁前面还有一个未申请成功的X锁,所以S锁必须等待,所以形成了循环等待,死锁出现了。

通过阅读死锁日志,我们可以清楚地知道两个事务形成了怎样的循环等待,再加以分析,就可以逆向推断出循环等待的成因,也就是死锁形成的原因。 

责任编辑:庞桂玉 来源: ITPUB
相关推荐

2017-07-28 15:40:01

数据库MySQL死锁与日志

2017-07-27 17:37:44

MySQL死锁日志

2021-07-04 22:29:12

MySQL死锁云日志

2020-07-16 21:20:08

数据库MySQL死锁

2021-03-26 10:40:16

MySQL锁等待死锁

2020-04-14 10:20:12

MySQL数据库死锁

2011-08-24 17:41:16

MySQL死锁

2023-11-09 11:56:28

MySQL死锁

2020-06-04 07:51:30

MySQL死锁加锁

2010-07-06 10:08:57

SQL Server

2017-06-14 22:11:57

数据库MySQL死锁

2017-10-18 15:07:21

MySQL执行死锁

2022-07-05 11:48:47

MySQL死锁表锁

2021-06-08 08:38:36

MySQL数据库死锁问题

2009-06-12 16:15:42

死锁Java虚拟机

2023-07-18 09:24:04

MySQL线程

2017-05-03 16:26:24

MySQL并发死锁

2018-01-04 10:08:08

2010-06-30 14:15:08

SQL Server死

2010-07-07 13:58:25

SQL Server死
点赞
收藏

51CTO技术栈公众号