?

两个小工具,MySQL死锁分析,新技能又Get!!!

数据死锁,是最难调试与追踪的。

场景如下:

数据库死锁

同一个表,事务内先插入一条记录,再更新这条记录,并发时会死锁

数据库死锁

并且能够复现。

可以通过什么工具模拟并发事务,查看信息,解决问题呢?这是今天要分享的内容。

一、前置准备

set session transaction isolation level repeatable read; 

set session autocommit=0

  

create table t ( 

id int(20) primary key AUTO_INCREMENT, 

cell varchar(20) unique 

)engine=innodb

  

start transaction; 

insert into t(cell) values(11111111111); 

insert into t(cell) values(22222222222); 

insert into t(cell) values(33333333333); 

commit

说明:

案发时,事务隔离级别RR;

多终端实验,需要关闭事务自动提交;

建表,设置PK与unique,初始化数据;

二、并发事务模拟

Session A: 

start transaction; 

insert into t(cell)values(44444444444);  [1] 

        Session B: 

        start transaction; 

        insert into t(cell) values(55555555555); [2] 

update t set cell=123 where cell=44444444444; [3]    

        update t set cell=456 where cell=55555555555; [4] 

开启两个终端模拟并发事务:

红色SQL为事务A;

黑色SQL为事务B;

[1][2][3][4]为执行时序;

三、实验现象

insert into t(cell)values(44444444444);  [1] 

事务A插入数据,最先执行

结果:插入成功

insert into t(cell) values(55555555555); [2] 

事务B插入数据,第二执行

结果:插入成果

update t set cell=123 where cell=44444444444; [3] 

事务A修改[1]中插入的数据,第三执行

结果:阻塞,等待执行结果

两个小工具,MySQL死锁分析,新技能又Get!!!

画外音:修改一条自己插入的数据,在等待什么呢?

update t set cell=456 where cell=55555555555; [4] 

事务B修改[2]中插入的数据,最后执行

结果:

事务B死锁,事务B被回滚;

两个小工具,MySQL死锁分析,新技能又Get!!!

事务A中,[3]语句阻塞结束,执行成功;

两个小工具,MySQL死锁分析,新技能又Get!!!

画外音:说明事务A中阻塞的语句,确实在等事务B中的某个锁。

四、结果分析

两个事务,各自修改自己插入的数据,却产生了死锁,确实诡异。

上述实验现象的两个核心问题是:

语句[3]阻塞,在等待什么锁?

语句[4]死锁,此时事务A和事务B一定是彼此占住一把锁,请求彼此的锁,这些锁又是什么呢?

工具一:

show engine innodb status; 

执行之后,显示的内容如下(放大仔细看):

两个小工具,MySQL死锁分析,新技能又Get!!!

信息很多,别急,楼主娓娓道来。

第一部分,关键词是:

Transaction 1,事务3998;

在执行

相关推荐
新闻聚焦
猜你喜欢
热门推荐
  • 微软AI面试题有多难?这里有一份样卷

      究竟什么样的AI人才能被微软这样的巨头聘用呢?今天,文摘君就淘来了几道微软AI 面试题,同时给出了最基本的解答......

    06-25????来源:澎湃新闻网

    分享
  • 全球最聪明的大脑怎么看AI?他们预测了

      2017年AI领域取得了诸多成果。2018年AI又将何去何从?以下是来自世界顶级研究人员和行业领军人物对2018年AI领域发展作......

    02-20????来源:虎嗅网

    分享
  • 2017JavaScript框架战报 - React分战场

      我们来看看与React有关的软件包的生态系统。当Facebook构建React时,就有许多来自开源社区的第三方软件包。为提供完......

    02-27????来源:湖北新闻网

    分享
  • 小白学数据:教你用Python实现简单监督学

      监督学习作为运用最广泛的机器学习方法,一直以来都是从数据挖掘信息的重要手段。即便是在无监督学习兴起的近......

    03-05????来源:今日头条

    分享
  • 现代编程语言Swift、Kotlin等十大有趣功能

      最近学习了一些现代编程语言,比如Reason,Swift,Kotlin和Dart。这些编程语言提供了许多新功能,本文主要分享了我认......

    04-29????来源:祁东新闻网

    分享
  • 领域场景分析的6W模型

      组成场景的要素常常被称之为6W模型,即描写场景的过程必须包含Who,What,Why,Where,When与hoW这六个要素。......

    04-30????来源:砍柴网

    分享
  • 开源应用服务器WildFly 12发新季度交付模式

      WildFly 12 Final版本现在已经可以下载了,WildFly是一款灵活的开源应用服务器,支持开发人员构建轻量级应用程序。支持......

    05-10????来源:青岛新闻网

    分享
  • 基于Spring Cloud的微服务落地

      微服务架构模式的核心在于如何识别服务的边界,设计出合理的微服务。但如果要将微服务架构运用到生产项目上,......

    06-04????来源:广西新闻网

    分享
  • 为什么阿里工程师纷纷在内网晒代码?

      前阵子,在阿里一个小黑屋里,5名对代码有着极致追求的工程师参与阿里代码领域最高荣誉“多隆奖”的最终角逐。......

    06-08????来源:四川新闻网

    分享
  • 超级大汇总!200多个最好的机器学习、

      我把这篇文章分为了四个部分:机器学习,自然语言处理,python和数学。在每个部分中我都列举了一些主题,但是因......

    09-25????来源:洛阳新闻网

    分享
返回列表
Ctrl+D?将本页面保存为书签,全面了解最新资讯,方便快捷。