首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQLmysql死锁以及死锁日志分析

1.死锁的概念 死锁死锁一般是事务相互等待对方资源,最后形成环路造成的。 对于死锁,数据库处理方法:牺牲一个连接,保证另外一个连接成功执行。...发生死锁会返回ERROR:1213 错误提示,大部分的死锁InnoDB存储引擎本身可以侦测到,不需要人为进行干预。...18514656666' where mobile='18514656620'; 空 5 空 delete from info_area where id=1; image.png image.png 分析死锁日志...uid='bbb';等待 空 4 ERROR 1213 (40001) insert INTO users VALUES(2,'bbb'); 成功 image.png image.png 分析死锁日志...通过阅读死锁日志,我们可以清楚地知道两个事务形成了怎样的循环等待,再加以分析,就可以逆向推断出循环等待的成因,也就是死锁形成的原因。

3.6K41

MySQL死锁分析

这里就介绍一下对MySQL死锁的理解,并提出一个基于审计日志分析死锁的方法。 一、死锁场景 我们创建一个最简单的死锁场景 1....死锁检测 MySQL死锁检测是通过wait-for graph来实现的,它是一个有向图。...四、如何分析死锁 通常的分析,都是看死锁日志,在结合业务执行的逻辑进行分析。如果只是上文中的简单case,还是比较容易的。...但复杂的,多个事务相互依赖的情况,通过死锁日志提供的信息,再加上当时分析业务逻辑,可能也不是很容易。 五、通过审计日志分析死锁 分析死锁的根本目标,是找到业务如何执行SQL,构成死锁的。...通过分析innodb_lock_waits+innodb_trx中的信息,可以得到造成死锁的SQL信息。 另外一种是解析法。

1.5K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL死锁案例分析

    本文针对上一篇《MySQL优化案例分享》文章中提到的线上业务产生的一个死锁问题进行展开讨论,主要针对两个update操作导致的死锁的场景,借此机会正好总结下MySQL锁及分析下产生死锁的原因和解决方案;...首先,针对MySQL中提供的锁种类做一个简单的总结,关于更多MySQL锁相关的内容可参考官方文档; MySQL InnoDB存储引擎提供了如下几种锁: 1、共享/排他锁(S/X锁) 共享锁(S Lock...案例分析 MySQL版本:MySQL 5.7 隔离级别:RC Session1 Session2 T1 begin;select * from locktest where name=’test’ lock...那么我们通过对上述操作,结合死锁日志进行分析: Session1的lock in share mode获取到S锁(lock mode S locks rec but not gap),Session1的...在该场景下,将update操作改为delete会得到同样的效果,同样也会产生死锁; 那么为什么会出现死锁呢?

    2.3K20

    故障分析 | MySQL死锁案例分析

    希望能够对想了解死锁的朋友有所帮助。二 案例分析2.1 业务逻辑select for update 表记录并加上 x 锁,查询数据,做业务逻辑处理,然后删除该记录。...2.2 环境说明数据库 MySQL 8.0.30 事务隔离级别 REPEATABLE-READcreate table dl(id int auto_increment primary key,c1...heap no 8 PHYSICAL RECORD: n_fields 2; compact format; info bits 0*** WE ROLL BACK TRANSACTION (2)2.5 死锁分析...三 小结敲黑板 ,重点: 死锁是因为不同事务对表记录加锁的顺序不一致导致相互等待对方持有的锁导致的。大家在分析死锁的时候能基于该原则去分析理清业务的sql 逻辑,基本上都能解决大部分的问题场景。...另外文章的最后我们再次复习一下 MySQL 的加几个基本原则,方便大家后面遇到死锁案例进行分析:原则 1:加锁的基本单位是 next-key lock。原则 2:查找过程中访问到的对象才会加锁。

    84230

    故障分析 | MySQL死锁案例分析

    本次分享的死锁案例是 更新不存在的记录加上 X GAP lock 和 insert 的意向锁冲突。希望能够对想了解死锁的朋友有所帮助。...tables in use 1, locked 1LOCK WAIT 4 lock struct(s), heap size 1128, 3 row lock(s), undo log entries 1MySQL...heap no 4 PHYSICAL RECORD: n_fields 2; compact format; info bits 0*** WE ROLL BACK TRANSACTION (2)2.5 死锁分析...小结敲黑板 ,重点: 死锁是因为不同事务对表记录加锁的顺序不一致导致相互等待对方持有的锁导致的。大家在分析死锁的时候能基于该原则去分析理清业务的sql 逻辑和执行顺序,基本上都能解决大部分的问题场景。...另外文章的最后我们再次复习一下 MySQL 的加几个基本原则,方便大家后面遇到死锁案例进行分析:原则 1:加锁的基本单位是 next-key lock。原则 2:查找过程中访问到的对象才会加锁。

    77140

    MySQL批量更新死锁案例分析

    问题描述 在做项目的过程中,由于写SQL太过随意,一不小心就抛了一个死锁异常,如下: com.mysql.jdbc.exceptions.jdbc4.MySQLTransactionRollbackException...原因分析 mysql的事务支持与存储引擎有关,MyISAM不支持事务,INNODB支持事务,更新时采用的是行级锁。这里采用的是INNODB做存储引擎,意味着会将update语句做为一个事务来处理。...蛋疼的情况出现了,一条语句获取了idx_1上的锁,等待主键索引上的锁;另一条语句获取了主键上的锁,等待idx_1上的锁,这样就出现了死锁。...中,更新操作默认会加行级锁,行级锁是基于索引的,在分析死锁之前需要查询一下mysql的执行计划,看看是否用到了索引,用到了哪个索引,对于没有用索引的操作会采用表级锁。...在并发度高的应用中,批量更新一定要带上记录的主键,优先获取主键上的锁,这样可以减少死锁的发生。

    2.2K40

    一次线上Mysql死锁分析

    ,上表省略了许多字段,但不影响我们分析; 这个表用来保存用户的收货地址,下单时需要选择相应的收货地址;通过查看日志平台日志,出问题的主要发生在添加地址的场景。...发现问题后,第一时间断定是多次请求了,因为通过相关SQL语句分析,上面的语句只会影响到某个用户自己的地址,没有操作太多的数据; 通过查看日志平台的日志,也证实了假设。...为什么同一个用户请求同时出现2次,这个后面分析;先分析执行同样的SQL,什么会发生死锁呢,可以复现下,先插入数据: INSERT INTO `oneplus_user`....为什么会死锁呢,我们分析下上面的SQL执行过程中获取的锁情况: 假设用户(ID为1)只有一条地址,即addr_id为100,则在执行update语句的时候需要获取3个锁: 锁1、idx_user_id索引中...为什么同一个用户添加地址的请求同时会出现2条,发现代码中用了Redis锁,锁定时间是2秒,但数据库因为用的是5.6版本的,无法设置超时时间,也没有定时查询过长时间的查询机制,导致应用服务器认为请求超时了,但后台Mysql

    58720

    MySQL锁等待与死锁问题分析

    前言:  在 MySQL 运维过程中,锁等待和死锁问题是令各位 DBA 及开发同学非常头痛的事。出现此类问题会造成业务回滚、卡顿等故障,特别是业务繁忙的系统,出现死锁问题后影响会更严重。...本篇文章我们一起来学习下什么是锁等待及死锁,出现此类问题又应该如何分析处理呢? 1.了解锁等待与死锁 出现锁等待或死锁的原因是访问数据库需要加锁,那你可能要问了,为啥要加锁呢?...死锁与锁等待稍有不同,我们同样也来简单复现下死锁现象。...,根据死锁日志,结合业务逻辑来进一步定位死锁原因。...总结: 本篇文章简单介绍了锁等待及死锁发生的原因,其实真实业务中发生死锁还是很难分析的,需要一定的经验积累。本篇文章只是面向初学者,希望各位对死锁能够有个初印象。

    2K20

    mysql insert duplicate key update 死锁分析

    背景 数据入库这块有离线和实时两套入库系统,写同一个db的同一批mysql表,两边用的都是insert into table on duplicate key update这种方式。...实时一直运行,离线5分钟更新一次,当两套系统同时运行时出现了死锁问题,频率还挺高。事务的隔离级别是read committed 读提交。...原因分析&解决方案 这里面分两种情况,一种是带主键的insert duplicate key update,一种是没有主键带唯一索引的insert duplicate key update。...此时实时任务获取了id为1数据的锁,等2的数据锁,离线任务获取了id为2的数据锁,等id为1数据锁,产生了死锁。...这种情况比较简单,处理方式有两种: 1、减少batch大小,减少了同一批数据中包含相同数据的概率,也就减少了死锁发生的概率 2、入库前对sql按照id排序,即使出现相同数据,只要保证顺序相同就不会出现死锁

    4.1K11

    MySQL PXC 集群死锁分析案例-2

    接前文 二、节点日志分析108节点 ■■ 以下日志显示,3:18分109节点出现问题(问题详见"109节点日志分析"),继而109节点被驱逐出去集群。...reported: ''mysql_native_password' is dep recated and will be removed in a future release....三、节点日志分析110节点 ■■ 前面的日志同108节点 ■■ 4:03的日志显示,109节点再次加入未成,继续被驱逐出集群。...总结以上分析过程,以下按照时间顺序客观描述一些症状、现象,以利于找到问题的根本原因。...一线分析参考: 本次故障是一线异步导出全网数据时,后台会同时更新XX平台割接过来的XXX关系状态,导出数据量过大时,出现了大事务提交,导致备库节点异常,从而整个PXC集群各节点数据同步卡死,最终导致事务提交不了

    11010

    MySQL死锁系列-常见加锁场景分析

    在上一篇文章《锁的类型以及加锁原理》主要总结了 MySQL 锁的类型和模式以及基本的加锁原理,今天我们就从原理走向实战,分析常见 SQL 语句的加锁场景。...隔离等级对加锁的影响 MySQL 的隔离等级对加锁有影响,所以在分析具体加锁场景时,首先要确定当前的隔离等级。...具体场景分析 具体 SQL 场景分析主要借鉴何登成前辈的《MySQL 加锁处理分析》文章和 aneasystone 的系列文章,在他们的基础上进行了总结和整理。...聚簇索引,查询命中 聚簇索引就是 InnoDB 存储引擎下的主键索引,具体可参考《MySQL索引》。...我们需要使用 MySQL 相关的工具进行分析,并且有时甚至需要查询 MySQL 相关的日志信息来了解到底语句加了什么锁或者为什么产生死锁,下篇文章中我们就主要了解一下这些内容,请大家持续关注。

    1.7K00

    大招落地:MySQL 插入更新死锁源码分析

    读者反馈了一个死锁案例,比较有意思,上一篇文章讲了怎么通过调试源码来分析锁,今天再来分析一个死锁场景。...看这篇文章需要有一些基础,下面是我在掘金上写的五篇调试源码分析死锁的文章,可以顺便看看: https://juejin.im/post/5ce287326fb9a07ea8039d70 https://...ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transaction 分析过程如下: 事务 1...trx 等待锁的事务指针 死锁的本质是:在递归过程中,如果冲突出现的锁事务id等于顶层事务id(lock_trx == start),则说明有环,就发生死锁。...我画了一个图方便你理解: 后记 死锁分析是比较复杂的,调试源码可以比较清晰的理清思路,上面是我调试源码的一些结论,如果有理解有误的地方,记得及时帮我指出。

    71330

    手把手教你分析Mysql死锁问题

    本文将跟你一起探讨这个问题 准备好数据环境 模拟死锁案发 分析死锁日志 分析死锁结果 环境准备 数据库隔离级别: mysql> select @@tx_isolation; +-...mysql> insert into account values(null,'Yan',100); Query OK, 1 row affected (0.01 sec) 锁介绍 在分析死锁日志前,...我们接下来一小节详细分析一波,一个一个问题来~ 死锁分析 死锁死循环四要素 互斥条件:指进程对所分配到的资源进行排它性使用,即在一段时间内某资源只由一个进程占用。...~ 总结 最后,遇到死锁问题,我们应该怎么分析呢?...模拟死锁场景 show engine innodb status;查看死锁日志 找出死锁SQL SQL加锁分析,这个可以去官网看哈 分析死锁日志(持有什么锁,等待什么锁)

    44731

    mysql insert 时出现Deadlock死锁场景分析

    当两个事务尝试同时修改同一数据时,如果没有合适的锁策略,就可能发生死锁死锁的定义死锁是指两个或多个事务在执行过程中,因争夺资源而造成的一种僵局。...MySQL中常见的锁分类:全局锁(Global Locks)全局读锁(Global Read Lock)全局写锁(Global Write Lock)表级锁(Table-level Locks)表共享读锁...如果两个事务几乎同时开始,并且都试图获取对方的锁,就可能发生死锁。解决死锁的策略1. 避免循环等待确保事务以相同的顺序请求资源,可以减少死锁的可能性。2....死锁检测数据库管理系统可以定期检测死锁情况,并在检测到死锁时自动选择一个事务进行回滚。4. 减少锁的粒度尽量使用更细粒度的锁,如行锁代替表锁,可以减少锁的冲突。5....避免长事务长事务持有锁的时间较长,增加了死锁的风险。尽量缩短事务的执行时间。结语死锁是并发编程中不可避免的一部分,但通过合理的设计和策略,我们可以最大限度地减少它对应用的影响。

    28430

    手把手教你分析Mysql死锁问题

    前言 前几天跟一位朋友分析了一个死锁问题,所以有了这篇图文详细的博文,哈哈~ ? 发生死锁了,如何排查和解决呢?...本文将跟你一起探讨这个问题 准备好数据环境 模拟死锁案发 分析死锁日志 分析死锁结果 环境准备 数据库隔离级别: mysql> select @@tx_isolation;+--------------...锁介绍 在分析死锁日志前,先做一下锁介绍,哈哈~ ?...死锁的死循环是怎么形成的?目前日志看不出死循环构成呢? 我们接下来一小节详细分析一波,一个一个问题来~ 死锁分析 死锁死循环四要素 ?...模拟死锁场景 show engine innodb status;查看死锁日志 找出死锁SQL SQL加锁分析,这个可以去官网看哈 分析死锁日志(持有什么锁,等待什么锁) 熟悉锁模式兼容矩阵,InnoDB

    64822

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券