---- 简介 ---- 在 Java避坑指南:使用锁排序和尝试获取所有锁来避免死锁 中介绍了开发中如何避免死锁,那我们如何去定位或主动发现死锁的现象呢?...定位死锁-ThreadMXBean监控工具 ---- java的线程监控工具ThreadMXBean,提供了方法:findDeadlockedThreads来检测死锁。...死锁示例: 利用ThreadMXBean检测死锁并打印死锁相关信息: 死锁相关信息输出: 定位死锁-在线工具FastThread ---- FastThread可能是分析生产环境中线程Dump文件的最佳在线工具...最后,它还包括同步器和忽略的行: 如何修复死锁 ---- 在生产环境,绝大部分都是赶紧离线出问题的服务即:从注册中心下线,保留现场,利用上面的分析工具去分析死锁的原因,当然如何想好彻底杜绝死锁,必须在编码阶段养成良好的编码习惯了...小结 ---- 如果死锁发生了,我们提供了几种定位死锁,修复死锁的几种方法。 1、Java避坑指南:使用锁排序和尝试获取所有锁来避免死锁
死锁是指多个进程(线程)因为长久等待已被其他进程占有的的资源而陷入阻塞的一种状态。当等待的资源一直得不到释放,死锁会一直持续下去。...死锁一旦发生,程序本身是解决不了的,只能依靠外部力量使得程序恢复运行,例如重启,开门狗复位等。 所以内核中设计了内核死锁检测机制,一旦发现死锁进程,就重启OS,快刀斩乱麻解决问题。...之所以使用重启招数,还是在于分布式系统中可以容忍单点崩溃,不能容忍单点进程计算异常,否则进行死锁检测重启OS就得不偿失了。
常见的死锁有如下两种: 递归死锁:中断等延迟操作中使用了锁,和外面的锁构成了递归死锁。 AB-BA死锁:多个锁因处理不当而引发死锁,多个内核路径上的所处理顺序不一致也会导致死锁。...Linux内核提供死锁调试模块Lockdep,跟踪每个锁的自身状态和各个锁之间的依赖关系,经过一系列的验证规则来确保锁之间依赖关系是正确的。 2....首先从死锁描述大概可以知道死锁类型。 然后详细介绍了产生死锁的点,这时就可以大概知道是哪个锁,有哪些地方调用导致了死锁。 接着是详细的发生死锁的backtrace,有助于分析死锁产生时的栈回溯。...首先是死锁类型介绍。 然后是产生死锁的两个点的调用者,再详细给出了两个点的栈回溯。 最后是死锁点的详细栈回溯。 ?...参考文档 《Linux 死锁检测模块 Lockdep 简介》 内核帮助文档:Documentation/locking/
最后构造不同死锁用例,并分析如何根据lockdep输出发现问题根源。 1. Lockdep介绍 死锁是指两个或多个进程因争夺资源而造成的互相等待的现象。...常见的死锁有如下两种: 递归死锁:中断等延迟操作中使用了锁,和外面的锁构成了递归死锁。 AB-BA死锁:多个锁因处理不当而引发死锁,多个内核路径上的所处理顺序不一致也会导致死锁。...Linux内核提供死锁调试模块Lockdep,跟踪每个锁的自身状态和各个锁之间的依赖关系,经过一系列的验证规则来确保锁之间依赖关系是正确的。 2....首先从死锁描述大概可以知道死锁类型。 然后详细介绍了产生死锁的点,这时就可以大概知道是哪个锁,有哪些地方调用导致了死锁。 接着是详细的发生死锁的backtrace,有助于分析死锁产生时的栈回溯。...首先是死锁类型介绍。 然后是产生死锁的两个点的调用者,再详细给出了两个点的栈回溯。 最后是死锁点的详细栈回溯。
如果你经验丰富,可以判断这是复位问题。 为验证是否复位问题,我们可以执行命令手工发出复位信号,先确定LCD复位引脚是哪个GPIO: ?...如果没有手册,怎么办? 触摸屏的主控芯片一般都是I2C接口的,那么我们可以把屏接到板子上,用i2cdetect检测出I2C设备的地址,根据地址就可以知道它的型号。...它接在哪个I2C控制器上? b. 它的I2C地址是? c. 复位引脚使用哪个GPIO?低电平有效还是高电平有效? d. 中断引脚使用哪个GPIO?低电平有效还是高电平有效? 不知道怎么写?...即怎么改成100ASK_IMX6ULL所用的GPIO引脚 前面说过,根据I2C设备的地址0x38,执行如下命令: $ cd arch/arm/boot/dts/ $ grep "@38" * -nR...怎么修改设备树?
7、I2C死锁 在实际使用过程中,I2C比较容易出现的一个问题就是死锁 ,死锁在I2C中主要表现为:I2C死锁时表现为SCL为高,SDA一直为低。...如果这个时候主设备异常复位,SCL就会被释放为高电平。此时,如果从设备没有复位,就会继续I2C的应答,将SDA一直拉为低电平,直到SCL变为低电平,才会结束应答信号。...而对于I2C主设备来说,复位后检测SCL和SDA信号,如果发现SDA信号为低电平,则会认为I2C总线被占用,会一直等待SCL和SDA信号变为高电平。...这样,I2C主设备等待从设备释放SDA信号,而同时I2C从设备又在等待主设备将SCL信号拉低以释放应答信号,两者相互等待,I2C总线进人一种死锁状态。...同样,当I2C进行读操作,I2C从设备应答后输出数据,如果在这个时刻I2C主设备异常复位而此时I2C从设备输出的数据位正好为0,也会导致I2C总线进入死锁状态。
采用了 MCU 的硬件 I2C 控制器。 24LC02硬件连接:A2,A1,A0 接 GND, 地址为 A0。WP 接 GND,允许写入。...https://github.com/TopSemic/STM32_Controller_24C02 网上有很多抱怨使用硬件 I2C 控制器不稳定,采用 GPIO 模拟 I2C 时序的同学。...硬件 I2C 其实也是可以稳定运行的,需要注意以下几点: 1. 看一下芯片勘误表 Errata,有没有已知 Bug。 2. I2C 操作中途被打断,或受到脉冲干扰,SCL, SDA 可能被拉低锁死。...这里需要注意,拉低总线的并不一定是从器件,有客户在总线锁死后,把 SCL SDA 线割断后发现这两根线任然是拉低的 (主控制器模块因为时序问题进入死锁)。 3....选用带复位输人的 I2C 从器件。 5. 控制 I2C 从设备的电源,死锁后重新上电。 采用哪些方法,还是要综合考虑可靠性要求和成本。
什么是数据库死锁 在操作系统领域当中,死锁指的是两个或者两个以上的进程在运行的过程中,因为争夺共同的访问资源而相互等待阻塞,最终导致进程继无法续执行的一种阻塞现象。...那么在数据库领域当中死锁又是怎样的表现形式呢?数据库死锁又会带来怎样的问题呢? 在理解数据库死锁之前,我们先来明确下数据库的锁到底是什么?...那么数据库出现死锁又会导致什么问题呢?数据库死锁会导致严重的性能问题,可能平台因为数据库死锁而导致运行缓慢,严重影响用户正常使用业务,因此如果出现数据库死锁情况需要及时发现以及解决。...定位死锁 //先确定数据库有没有死锁情况发生 select * from pg_stat_activity where datname = 'product_db'; //查询可能锁了的表的oid select...避免死锁的建议 (1)如果平台中存在大事务,尽量将其拆分为小事务。因为大事务一般操作的数据库表或者数据都比较多,因此造成死锁或者阻塞的概率就会相对较大。
采用了 MCU 的硬 I2C 控制器。 24LC02硬件连接: A2,A1,A0 接 GND, 地址为 A0。 WP 接 GND,允许写入。...网上有很多抱怨使用硬件 I2C 控制器不稳定,常常死机,所以转而采用 GPIO 模拟 I2C 时序的同学。我们还是不推荐用模拟的方法,它会耗费比较多的MCU 系统时间。...硬件 I2C 其实也是可以稳定运行的,需要注意以下几点: 1. 看一下芯片勘误表 Errata,有没有已知 Bug。 2. I2C 操作中途被打断,或受到脉冲干扰,SCL, SDA 可能被拉低锁死。...这里需要注意,拉低总线的并不一定是从器件,有客户在总线锁死后,把 SCL SDA 线割断后发现这两根线任然是拉低的(主控制器模块因为时序问题进入死锁)。 3....选用带复位输人的 I2C 从器件。 5. 控制 I2C 从设备的电源,死锁后重新上电。 采用哪些方法,还是要综合考虑可靠性要求和成本。 下面是实测的 24C02 读写时序: Byte Write ?
我们使用锁来保证线程安全,但是使用不当与滥用可能就会引起死锁。并发程序一旦死锁,一般没有特别好的办法,很多时候只能重启。所以我们一定要比避免死锁。...相互等待对方释放形成了死锁。 死锁检查 jstack 指令 该指令可以生成虚拟机当前时刻的线程快照。...死锁预防 我们知道了死锁如何产生的,那么就知道该如何去预防。如果一个线程每次只能获取一个锁,那么就不会出现由于嵌套持有锁顺序导致的死锁。 1....其他死锁 我们再来回顾一下死锁的定义,“死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。”...另外有些时候,死锁并不会马上在应用程序中体现出来,在通常情况下,都是应用在生产环境运行了一段时间后,才开始慢慢显现出来,在实际测试过程中,由于死锁的隐蔽性,很难在测试过程中及时发现死锁的存在,而且在生产环境中
在死锁发生时产生的死锁日志来逆向定位一下到底是什么语句产生了死锁,从而再优化我们的业务。...查看死锁日志 设计InnoDB的大叔给我们提供了SHOW ENGINE INNODB STATUS命令来查看关于InnoDB存储引擎的一些状态信息,其中就包括了系统最近一次发生死锁时的加锁情况。...TRANSACTION 30477, ACTIVE 10 sec starting index read # 此事务使用了1个表,为1个表上了锁(此处不是说为该表加了表锁,只要不是进行一致性读的表,都需要加锁,具体怎么加锁请看加锁语句分析或者小册章节...思索分析的思路 查看死锁日志时,首先看一下发生死锁的事务等待获取锁的语句都是啥。...找到发生死锁的事务中所有的语句之后,对照着事务获取到的锁和正在等待的锁的信息来分析死锁发生过程。
insert 语句是怎么加锁的? 提纲如下: 正文 有个业务主要逻辑就是新增订单、修改订单、查询订单等操作。...而正是因为这样的操作,当业务量很大的时候,就可能会出现死锁。 接下来跟大家聊下为什么会发生死锁,以及怎么避免死锁。 死锁的发生 本次案例使用存储引擎 Innodb,隔离级别为可重复读(RR)。...接下来,我用实战的方式来带大家看看死锁是怎么发生的。...Insert 语句是怎么加行级锁的? Insert 语句在正常执行时是不会生成锁结构的,它是靠聚簇索引记录自带的 trx_id 隐藏列来作为隐式锁来保护记录的。 什么是隐式锁?...当发生超时后,就出现下面这个提示: 图片 开启主动死锁检测。主动死锁检测在发现死锁后,主动回滚死锁链条中的某一个事务,让其他事务得以继续执行。
Linux死锁检测 最近遇到了一个驱动上面的BUG,导致终端敲命令都无响应,最终导致内核触发了hung_task_timeout...... 为什么会出现这种情况?该如何排查?...B锁,再去获取A锁,这个时候处于的死锁状态 常见的死锁有以下4种情况: 进程重复申请同一个锁,称为AA死锁。...如果这种情况继续存在,将可能导致死锁的情况。 {+.+.}:是用来描述Linux内核中锁的状态的符号,也称作锁的标志位或锁标志。...在 Linux 内核调试中,报告锁状态通常都使用这种简洁的符号,通过观察锁标志位,可以快速地了解内核锁的状态,诊断性能问题和死锁问题。...在Linux内核中,每个锁的释放次数需要与该锁的获取次数相匹配,否则就会出现锁释放不平衡的情况。
死锁的产生方式 死锁代码 package com.an.learning.thread; import java.util.concurrent.TimeUnit; class HoldLockThread...} } } /** * @author Anzepeng * @title: DeadLockDemo * @projectName learning * @description: 死锁...0x00000000d635f928> 这个锁尝试占有这个锁 B持有 这个锁尝试占有这个锁 互相僵持产生死锁...jps命令定位进程号 jstack找到死锁查看
资料下载 coding无法使用浏览器打开,必须用git工具下载: git clone https://e.coding.net/weidongshan/linux/doc_and_source_for_drivers.git...硬件连接 I2C在硬件上的接法如下所示,主控芯片引出两条线SCL,SDA线,在一条I2C总线上可以接很多I2C设备,我们还会放一个上拉电阻(放一个上拉电阻的原因以后我们再说)。 2....传输数据类比 怎么通过I2C传输数据,我们需要把数据从主设备发送到从设备上去,也需要把数据从从设备传送到主设备上去,数据涉及到双向传输。...主、从设备都可以通过SDA发送数据,肯定不能同时发送数据,怎么错开时间?...当它就绪后,就可以不再驱动三极管,这是上拉电阻把SCL变为高电平,其他设备就可以继续使用I2C总线了。 对于IIC协议它只能规定怎么传输数据,数据是什么含义由从设备决定。
Linux内核将 I2C 驱动分为两部分: I2C 总线驱动, I2C总线驱动就是SOC的 I2C控制器驱动,也叫做 I2C适配器驱动。...I2C驱动 i2c_driver 类似 platform_driver,是我们编写 I2C 设备驱动重点要处理的内容, i2c_driver 结构体定义在 include/linux/i2c.h 文件中...I2C设备 I2C设备结构体i2c_client 结构体定义在 include/linux/i2c.h 文件中,内容如下: struct i2c_client { unsigned short...Linux 内核将 SOC 的 I2C 适配器(控制器)抽象成 i2c_adapter, i2c_adapter 结构体定义在 include/linux/i2c.h 文件中,结构体内容如下: /*...Linux I2C总线的运行机制: 注册I2C驱动 将I2C驱动添加到I2C总线的驱动链表中 遍历I2C总线上的设备链表,根据i2c_device_match函数进行匹配,如果匹配调用i2c_device_probe
\MDK-ARM\Project.uvprojx Step 1, 把 I2C 地址改为跟我们硬件一致: ?...Step 2, 根据实际使用的 I2C 模块和引脚进行配置: ? Step 3, 把地址模式改为 7BIT: ?...注意: 在使用硬件 I2C 操作时,有时候会遇到死锁问题。...在此情况下,可以把 SCL,SDA 引脚初始化为 GPIO,如此例中的 PB8, PB9 然后连续翻转 SCL 引脚送出 9 个时钟脉冲,既可以使 I2C 从死锁的状态复位。...然后再重新初始化 I2C 模块,进入正常 I2C 操作。
资料下载 coding无法使用浏览器打开,必须用git工具下载: git clone https://e.coding.net/weidongshan/linux/doc_and_source_for_drivers.git...I2C硬件框架 在一个芯片(SoC)内部,有一个或多个I2C控制器 在一个I2C控制器上,可以连接一个或多个I2C设备 I2C总线只需要2条线:时钟线SCL、数据线SDA 在I2C总线的SCL、SDA...AT24C02驱动: 它知道AT24C02要求的地址、数据格式 它知道发出什么信号才能让AT24C02执行擦除、烧写工作 它知道怎么判断数据是否烧写成功 它构造好一系列的数据,发给I2C控制器...I2C控制器驱动 它根据I2C协议发出各类信号:I2C设备地址、I2C存储地址、数据 它根据I2C协议判断 3....我们讲什么 3.1 对于Linux 从上到下: 先讲I2C协议 APP可以通过两类驱动程序访问设备 I2C设备自己的驱动程序 内核自带的i2c-dev.c驱动程序,它是i2c控制器驱动程序暴露给用户空间的驱动程序
死锁产生的四个必要条件: 互斥:一个资源每次只能被一个进程使用(资源独立) 请求与保持:一个进程因请求资源而阻塞时,对已获得的资源保持不放(不释放锁) 不剥夺:进程已获得的资源,在未使用之前,不能强行剥夺...(抢夺资源) 循环等待:若干进程之间形成一种头尾相接的循环等待的资源关闭(死循环) 避免死锁的方法: 第一个条件 "互斥" 是不能破坏的,因为加锁就是为了保证互斥 一次性申请所有的资源,破坏 "占有且等待
死锁 概念 指一组进程中的各个进程均占有不会释放的资源, 但因互相申请被其他进程所占用不会释放的资源而处于的一种永久等待的状态 ---- 有两个小朋友,张三和李四,共同去了一家商店,想要向老板 购买一块价值...老板 为操作系统 想要访问临界资源,必须同时拥有两把锁 ---- 两个线程各自持有自己的锁,并向对方申请锁,从而导致互相申请锁不成功,进而导致双执行流互相被挂起 访问临界资源的临界区代码,无法得以推进 死锁的必要条件...不剥夺: 一个执行流已获得的资源,在未使用完之前,不能强行剥夺 假设张三的块头比李四大,若李四不给属于他自己的5毛钱,张三就要揍李四,把李四的5毛钱枪过来 就不会有死锁问题了,所以要求不能打人抢钱 如何避免死锁...核心思想:破坏死锁的4个必要条件的任意一个 ---- 1. 不加锁 ---- 2....控制线程统一释放锁 将所有线程 申请的锁 使用一个线程 全部释放掉,就不会出现死锁了 证明 一个线程申请一把锁,可以由另一个线程释放 设置一个全局锁mutex,再自定义函数中由于两次申请锁,所以在第二次申请锁时
领取专属 10元无门槛券
手把手带您无忧上云