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

MySQL死锁系列-线上死锁问题排查思路

前言 MySQL 死锁异常是我们经常会遇到的线上异常类别,一旦线上业务日间复杂,各种业务操作之间往往会产生锁冲突,有些会导致死锁异常。...本篇文章会讲解一下如果线上发生了死锁异常,如何去排查和处理。除了系列前文讲解的有关加锁和锁冲突的原理还,还需要对 MySQl 死锁日志和 binlog 日志进行分析。...[线上死锁异常分析] 正文 日常工作中,应对各类线上异常都要有我们自己的 SOP (标准作业流程) ,这样不仅能够提高自己的处理问题效率,也有助于将好的处理流程推广到团队,提高团队的整体处理异常能力。...所以,面对线上偶发的 MySQL 死锁问题,我的排查处理过程如下: 线上错误日志报警发现死锁异常 查看错误日志的堆栈信息 查看 MySQL 死锁相关的日志 根据 binlog 查看死锁相关事务的执行内容...我们可以使用 MySQL 的命令行工具 Mysqlbinlog 远程获取线上数据库的 binlog 日志。

5.5K32

【说站】java使用JConsole检测死锁

java使用JConsole检测死锁 说明 Jconsole是JDK自带的监视工具,可以在JDK/bin目录中找到。...该软件用来连接运行中的本地或远程JVM,监视Java应用程序运行的资源消耗和性能,绘制大量图表,提供功能强大的可视界面。而服务器所占用的内存非常少,甚至可以说几乎没有消耗。...检测流程 1、点击命令行上的jconsole命令,对话框将自动弹出,选择进程1362,然后点击链接; 2、输入检测到的进程,选择“线程”标签,然后点击“检测死锁”。...使用ReentrantLock制作死锁一次,再使用死锁检测工具,同样可以检测死锁,但是显示的信息会更丰富。 以上就是java使用JConsole检测死锁的方法,希望对大家有所帮助。

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

    一次线上Mysql死锁分析

    发生死锁的是用户地址表,先贴下表结构: CREATE TABLE `user_address` ( `addr_id` int(11) unsigned NOT NULL AUTO_INCREMENT...插入成功,然后开始执行Update语句,而同一个用户的另一个请求在 10:00:44.130 插入成功,从这个时间至 10:00:45.523 修改成功 即在44.895开始两个事务是重叠在跑的,造成了死锁...为什么同一个用户请求同时出现2次,这个后面分析;先分析执行同样的SQL,什么会发生死锁呢,可以复现下,先插入数据: INSERT INTO `oneplus_user`....where user_id = 1 and (addr_id = 100 or is_default = 1); 其中1为用户ID,100为已经存的地址ID;先都执行插入语句,再执行update,必然死锁...为什么会死锁呢,我们分析下上面的SQL执行过程中获取的锁情况: 假设用户(ID为1)只有一条地址,即addr_id为100,则在执行update语句的时候需要获取3个锁: 锁1、idx_user_id索引中

    59420

    java 查看线程死锁_java 查看线程死锁

    那我们怎么确定一定是死锁呢?有两种方法。 1>使用JDK给我们的的工具JConsole,可以通过打开cmd然后输入jconsole打开。 1)连接到需要查看的进程。...2)打开线程选项卡,然后点击左下角的“检测死锁” 3)jconsole就会给我们检测出该线程中造成死锁的线程,点击选中即可查看详情: 从上图中我们可以看出: ①在线程Thread-1中,从状态可以看出...Thread-1一直等待paper资源,而Thread–一直等待pen资源,于是这两个线程就这么僵持了下去,造成了死锁。...2>直接使用JVM自带的命令 1)首先通过 jps 命令查看需要查看的Java进程的vmid,如图,我们要查看的进程TestDeadLock的vmid号是7412; 2)然后利用 jstack 查看该进程中的堆栈情况

    2.7K30

    Java Concurrent 死锁

    前言 死锁是一个比较大的概念,在并发场景下的加锁行为都有可能产生死锁问题。...在Java 并发编程中会有死锁,操作系统里也有死锁,数据库里也见过死锁,分布式里也有死锁, 看上去蛮常见的,这一篇主要简单的介绍下死锁,然后说一说在并发编程中如何对待死锁。...死锁定义 死锁是指多个进程或线程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将继续等待下去,此时称系统处于死锁状态或系统产生了死锁。...处理死锁一般有这样几个场景: 1、死锁的预防 2、死锁的消除 3、死锁检测 死锁的预防策略 我觉这最好用的应该就是顺序取锁了 既然产生死锁有以上几个必要条件,那么破坏它们就好啦 1、锁超时、...死锁的消除 直接kill 在Java 多线程并发编程场景下,其实只要写代码时,除了数据在并发中的正确性,多少留心一下死锁,问题一般不大,毕竟没有那么多需要加锁的资源。

    58620

    Java并发-死锁

    一、死锁的简单概念  所谓死锁是指两个或两个以上的线程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无其余方法作用,它们都将无法推进下去。  ...其实死锁形成的关键就是:谁也不让谁,谁都不会主动地让步。...()->{ while (true){ otherService.o1(); } }).start(); } }  上述代码描述了Java死锁最简单的情况,一个线程Thread...导致了死锁。  虽然这种僵持情况由于线程程序运行时间可能错开,而不在程序运行的开始马上发生,但是这种结构的程序,若无其他代码进行死锁去除保障,那么死锁现象一定会发生。...这也是死锁的一个典型例子: 使用自己的线程对象作为同步锁,调用join方法,那么会造成死锁

    77820

    【说站】mysql死锁检测

    mysql死锁检测 说明 1、检测死锁:数据库系统实现了各种死锁检测死锁超时机制。 InnoDB存储引擎可以检测死锁的循环依赖,并立即返回错误。...2、外部锁的死锁检测:InnoDB不能完全自动检测死锁,则需要设置锁等待超时参数innodb_lock_wait_timeout来解决。...发生死锁后,InnoDB一般自动检查,一个事务释放锁后退,另一个事务获得锁,继续完成事务。...但是,如果涉及外部锁或表部锁,InnoDB不能完全自动检测死锁,则需要设置锁等待超时参数innodb_lock_wait_timeout来解决。...if (too_far) {                   return(LOCK_EXCEED_MAX_DEPTH);               } 以上就是mysql死锁检测,希望对大家有所帮助

    74520

    一次线上MySQL死锁告警原因排查

    项目场景:一次线上MySQL死锁告警原因排查 最近处理了一次线上数据告警,记录一下。...问题描述 同步书架书籍的接口频繁抛出异常,提示数据库出现死锁,异常如下: 本日异常次数:2,异常日志:java.lang.RuntimeException: org.springframework.dao.DeadlockLoserDataAccessException...这里可以通过SHOW ENGINE INNODB STATUS来查看最近捕获到的死锁日志 ===================================== 2022-04-01 10:41:02...SESSION: ---TRANSACTION 421145291578096, not started 0 lock struct(s), heap size 1136, 0 row lock(s) 死锁日志的结构很清晰...从日志里面可以看出 这是个批量插入操作,两个事物操作的数据是一样,由于添加了userId+bookId的唯一索引,两个事物之间会出现互相申请锁的情况,陷入等待循环,造成了死锁

    1.7K40

    SQL Server 中的死锁检测

    同样从 SQL Server 2012 (11.x) 开始,当发生死锁时,system_health会话已捕获xml_deadlock_report包含死锁图的所有 xEvent。...考虑使用扩展事件死锁事件而不是跟踪。...2012开始,可以直接在扩展事件里面查看到死锁日志。...最大限度地减少死锁尽管无法完全避免死锁,但遵循某些编码约定可以最大程度地减少产生死锁的机会。最大限度地减少死锁可以提高事务吞吐量并减少系统开销,因为更少的事务:回滚,撤消事务执行的所有工作。...由应用程序重新提交,因为它们在死锁时被回滚。为了帮助最大限度地减少死锁:以相同的顺序访问对象。避免交易中的用户交互。- 保持交易简短并集中进行。使用较低的隔离级别。

    35010

    Java死锁: 死锁发生了?怎么去定位死锁?怎么去修复死锁

    ---- 简介 ---- 在 Java避坑指南:使用锁排序和尝试获取所有锁来避免死锁 中介绍了开发中如何避免死锁,那我们如何去定位或主动发现死锁的现象呢?...定位死锁-jstack工具 ---- 利用java的命令行工具:jps + jstack 组合可以得到Thread Dump: jstack命令后,输出内容的最后一行很容易发现死锁现象。...定位死锁-ThreadMXBean监控工具 ---- java的线程监控工具ThreadMXBean,提供了方法:findDeadlockedThreads来检测死锁。...死锁示例: 利用ThreadMXBean检测死锁并打印死锁相关信息: 死锁相关信息输出: 定位死锁-在线工具FastThread ---- FastThread可能是分析生产环境中线程Dump文件的最佳在线工具...小结 ---- 如果死锁发生了,我们提供了几种定位死锁,修复死锁的几种方法。 1、Java避坑指南:使用锁排序和尝试获取所有锁来避免死锁

    50920

    线上发生死锁异常了,该怎么办

    前言 MySQL 死锁异常是我们经常会遇到的线上异常类别,一旦线上业务日间复杂,各种业务操作之间往往会产生锁冲突,有些会导致死锁异常。...本篇文章会讲解一下如果线上发生了死锁异常,如何去排查和处理。除了系列前文讲解的有关加锁和锁冲突的原理还,还需要对 MySQl 死锁日志和 binlog 日志进行分析。 ?...所以,面对线上偶发的 MySQL 死锁问题,我的排查处理过程如下: 线上错误日志报警发现死锁异常 查看错误日志的堆栈信息 查看 MySQL 死锁相关的日志 根据 binlog 查看死锁相关事务的执行内容...第一二步的线上错误日志和堆栈信息一般比较容易获得,第五步的分析 SQL 锁冲突原因中涉及的锁相关的理论在系列文章中都有介绍,没有了解的同学可以自行去阅读以下。...我们可以使用 MySQL 的命令行工具 Mysqlbinlog 远程获取线上数据库的 binlog 日志。

    1.2K20
    领券