Atitit.线程 死锁 跑飞 的检测与自动解除 与手动解除死锁 java c# .net php javascript.
Atitit.线程 死锁 跑飞 的检测与自动解除 与手动解除死锁 java c# .net php javascript.
1. 现象::主程序卡住无反应,多行任务不往下执行 1
2. 原因::使用jv jprofile查看线程,原来俩个线程死锁了。。 1
3. Java的缺点,默认不能自动解除死锁 1
4. 自动检测与解除死锁::使用看门狗watchdog 2
4.1. 死锁检测算法(太麻烦,不推荐) 2
4.2. 硬件看门狗 2
4.3. 软件看门狗的实现--TIMER 2
4.4. LINUX的watchdog 2
5. 解除死锁策略 3
5.1. 程序复位 3
5.2. 撤消线程,剥夺资源。 3
5.3. 进程回退策略, 3
6. 任务恢复---事务重做 3
7. 手动解除死锁 3
8. Watchdog原理and实现 4
9. Java的watchdog设计思路 4
10. 简单的会产生死锁现象的例子, 5
11. 参考 5
1. 现象::主程序卡住无反应,多行任务不往下执行
程序的跑飞,而陷入死循环,程序的正常运行被打断, 系统无法继续工作,会造成整个系统的陷入停滞状态,
2. 原因::使用jv jprofile查看线程,原来俩个线程死锁了。。
3. Java的缺点,默认不能自动解除死锁
不像数据库,许多数据库都可以自动解除死锁,然后安排事务重做。。
Java的语言级别无此功能,只能自己在类库级别实现次功能了。。
作者:: 老哇的爪子 Attilax 艾龙, EMAIL:1466519819@qq.com
转载请注明来源: http://blog.csdn.net/attilax
4. 自动检测与解除死锁::使用看门狗watchdog
死锁检测与恢复是指系统设有专门的机构,当死锁发生时,该机构能够检测到死锁发生的位置和原因,并能通过外力破坏死锁发生的必要条件,从而使得并发进程从死锁状态中恢复出来。
4.1. 死锁检测算法(太麻烦,不推荐)
4.2. 硬件看门狗
专门用于监测程序运行状态的芯片
4.3. 软件看门狗的实现--TIMER
4.4. LINUX的watchdog
Linux 自带了一个 watchdog 的实现,用于监视系统的运行,包括一个内核 watchdog module 和一个用户空间的 watchdog 程序。[1]
内核 watchdog 模块通过 /dev/watchdog 这个字符设备与用户空间通信。用户空间程序一旦打开 /dev/watchdog 设备,就会导致在内核中启动一个 1分钟的定时器,此后,用户空间程序需要保证在 1分钟之内向这个设备写入数据,每次写操作会导致重新设定定时器。如果用户空间程序在 1分钟之内没有写操作,定时器到期会导致一次系统 reboot 操作。[1]
看门狗,又叫 watchdog timer,是一个定时器电路, 一般有一个输入,叫喂狗, 正常工作的时候,每隔一段时间输出一个信号到喂狗端,给 WDT 清零,如果超过规定时间不喂狗(一般在程序跑飞时),WDT 定时超过,就会给出一个复位信号到 复位. 防止 死机. 看门狗的作用就是防止程序发生死循环或者说程序跑飞。
5. 解除死锁策略
5.1. 程序复位
(1)最简单,最常用的方法就是进行系统的重新启动,不过这种方法代价很大,它意味着在这之前所有的进程已经完成的计算工作都将付之东流,包括参与死锁的那些进程,以及未参与死锁的进程。
5.2. 撤消线程,剥夺资源。
终止参与死锁的进程,收回它们占有的资源,从而解除死锁。这时又分两种情况:一次性撤消参与死锁的全部进程,剥夺全部资源;或者逐步撤消参与死锁的进程,逐步收回死锁进程占有的资源。一般来说,选择逐步撤消的进程时要按照一定的原则进行,目的是撤消那些代价最小的进程,比如按进程的优先级确定进程的代价;考虑进程运行时的代价和与此进程相关的外部作业的代价等因素。
5.3. 进程回退策略,
即让参与死锁的进程回退到没有发生死锁前某一点处,并由此点处继续执行,以求再次执行时不再发生死锁。虽然这是个较理想的办法,但是操作起来系统开销极大,要有堆栈这样的机构记录进程的每一步变化,以便今后的回退,有时这是无法做到的。
6. 任务恢复---事务重做
进程回退策略,即让参与死锁的进程回退到没有发生死锁前某一点处,并由此点处继续执行,以求再次执行时不再发生死锁。虽然这是个较理想的办法,但是操作起来系统开销极大,要有堆栈这样的机构记录进程的每一步变化,以便今后的回退,有时这是无法做到的
7. 手动解除死锁
包装系统thread ,每当启动线程的时候儿,向线程注册表格插入线程..退出的时候儿clr...
要是死锁兰,马clr,能查询,在手动clr...
8. Watchdog原理and实现
看门狗的应用,使系统可以在无人状态下实现连续工作,其工作原理是:看门狗芯片和系统的一个I/O引脚相连(纯软件中通过一个变量相连),该I/O引脚通过程序控制它定时地往看门狗的这个引脚上送入高电平(或低电平,软件中是送入一个变量值),这一程序语句是分散地放在系统其他控制语句中间的,一旦系统由于干扰造成程序跑飞后而陷入某一程序段进入死循环状态时,写看门狗引脚的程序便不能被执行,这个时候,看门狗电路就会由于得不到系统送来的信号,便在它和系统复位引脚相连的引脚上送出一个复位信号,使系统发生复位,即程序从程序存储器的起始位置开始执行,这样便实现了系统的自动复位.
在系统运行以后也就启动了看门狗的计数器,看门狗就开始自动计数,如果到了一定的时间还不去清看门狗,那么看门狗计数器就会溢出从而引起看门狗中断,造成系统复位。所以在使用有看门狗的芯片时要注意清看门狗。
硬件看门狗是利用了一个定时器,来监控主程序的运行,也就是说在主程序的运行过程中,我们要在定时时间到之前对定时器进行复位如果出现死循环,或者说PC指针不能回来。那么定时时间到后就会使系统复位
软件看门狗技术的原理和这差不多,只不过是用软件的方法实现,我们还是以51系列来讲,我们知道在51系统中有两个定时器,我们就可以用这两个定时器来对主程序的运行进行监控。我们可以对T0设定一定的定时时间,当产生定时中断的时候对一个变量进行赋值,而这个变量在主程序运行的开始已经有了一个初值,在这里我们要设定的定时值要小于主程序的运行时间,这样在主程序的尾部对变量的值进行判断,如果值发生了预期的变化,就说明T0中断正常,如果没有发生变化则使程序复位。对于T1我们用来监控主程序的运行,我们给T1设定一定的定时时间,在主程序中对其进行复位,如果不能在一定的时间里对其进行复位,T1 的定时中断就会使系统复位。在这里T1的定时时间要设的大于主程序的运行时间,给主程序留有一定的的裕量。而T1的中断正常与否我们再由T0定时中断子程序来监视。这样就构成了一个循环,T0监视T1,T1监视主程序,主程序又来监视T0,从而保证系统的稳定运行。
9. Java的watchdog设计思路
系统软件"看门狗"的设计思路:
1.看门狗定时器T0的设置。在初始化程序块中设置T0的工作方式,并开启中断(timer事件)和计数功能。
2.计算主控程序循环一次的耗时。考虑系统各功能模块及其循环次数,本系统主控制程序的运行时间约为30。系统设置"看门狗"定时器T0定时60s
3.主控程序的每次循环都将刷新T0的初值。如程序进入"死循环"而T0的初值在60s内未被刷新,这时"看门狗"定时器T0将溢出并申请中断。
3.设计T0溢出所对应的中断服务程序。此子程序只须一条指令,即在T0对应的中断向量地址(000BH)(JAVA中是一个线程的引用),写入复位,对任务重新进行初始化并获得正确的执行顺序
10. 简单的会产生死锁现象的例子,
参考Java出现死锁了? - 推酷.htm
11. 参考
atitit 提升数据库死锁处理总结 - attilax的专栏 - 博客频道 - CSDN.NET.htm
watchdog_百度百科.htm
java 死锁产生原因及解锁 - hijiankang的专栏 - 博客频道 - CSDN.NET.htm
Atitit.线程 死锁 跑飞 的检测与自动解除 与手动解除死锁 java c# .net php javascript.相关推荐
- MySQL死锁详解及检测和避免
上一篇博客我们知道的Mysql事务的隔离机制和实现,以及锁的详细解析 链接: 详解MySQL脏读幻读不可重复读及事务的隔离级别和MVCC.LBCC实现,还有锁的详解 在我们使用锁的时候,有一个问题是需 ...
- 死锁四个必要条件及死锁的预防、检测、避免、解除
死锁: 我们先来思考一个问题:我们加锁以后,再次进行加锁,这样会发生什么? 当我们第二次申请锁的时候,这个时候锁已经被占用了,该线程就会被挂起,但是刚好这个线程就是拥有锁的线程了,那么这个线程就永远挂 ...
- 困扰一周的奇葩bug:重复相似代码多,导致单片机程序跑飞
今天是个好日子,困扰一周的bug终于解决了,迫不及待将这个奇葩问题分享给各位朋友~ 硬件环境: 国产MCU:华大HC32L130 问题描述: 最近做一款基于Modbus协议的三通道温度采集模块,程序设 ...
- 教你如何找到导致程序跑飞的指令
调试嵌入式程序时,你是否遇到过程序跑飞最终导致硬件异常中断的问题?遇到这种问题是否感觉比较难定位?不知道问题出在哪里,没有办法跟踪?尤其是当别人的程序踩了自己的内存,那就只能哭了:( 今天在论坛上看有 ...
- 2.4.4 死锁的处理策略-检测和解除
目录 思维导图 死锁的检测 死锁的解除 思维导图 死锁的检测 死锁的解除
- JAVA中如何确保N个线程可以访问N个资源,但同时又不导致死锁?
● JAVA中如何确保N个线程可以访问N个资源,但同时又不导致死锁? 考察点:死锁 参考回答: 使用多线程的时候,一种非常简单的避免死锁的方式就是:指定获取锁的顺序,并强制线程按照指定的顺序获取锁.因 ...
- MSP430程序跑飞原因
MSP430单片机的程序有时候容易出现跑飞的情况,导致运行不正常.常见原因总结如下: 没有设置停止看门狗,也没有及时喂狗 没有定义中断函数,但又开启了对应的中断,发生中断时,找不到中断函数入口 供电电 ...
- java jstack 死锁_利用jstack检测死锁DeadLock
首先,制造一个死锁程序如下: public class testJstack { final static Object obj_1 = new Object(); final static Obje ...
- (王道408考研操作系统)第二章进程管理-第四节3:死锁处理策略之检测和解除
文章目录 一:死锁检测算法 (1)资源分配图 (2)死锁定理 二:死锁解除算法 如果系统中既不采取预防死锁的措施,也不采取避免死锁的措施,系统就极有可能发生死锁,在这种情况下系统应当提供两个算法: 死 ...
- FPGA状态机跑飞原因分析
1.1 FPGA状态机跑飞原因分析 1.1.1 本节目录 1)本节目录: 2)本节引言: 3)FPGA简介: 4)FPGA状态机跑飞原因分析: 5)结束语. 1.1.2 本节引言 "不积跬步 ...
最新文章
- 重新学.Net[二]——从编译到运行
- 使用Apache来构建URL缩短服务
- linux 32库路径,linux – 共享库如何在64位/ 32位混合系统中工作?
- python中list[1啥意思_详解Python中list[::-1]的几种用法
- 【解题报告】Leecode 35. 搜索插入位置——Leecode刷题系列
- ProtoBuffer的.proto文件生成c++
- 用数学模型向你解释离婚
- 设计模式装饰者模式_装饰者模式如何拯救了我的一天
- easypoi设置黑色边框_迷人的G-SHOCK MTG-B1000XBD,碳纤维与黑色金属的魅力
- svmlib java_Libsvm Java
- Scikit-Learn简单操作
- 如何打造自己强大的气场?
- 集成学习 Bagging, Boosting, Stacking
- python安装request方法mac_Mac下python3使用requests库出现No module named 'requests'解决方法...
- 金庸群侠传修改器链接服务器,《金庸群侠传》6合1版修改器
- Win10微软拼音使用小鹤双拼方案
- github船舰新文件夹,为什么github显示灰色文件夹,当我创建一个新的存储库?
- Nginx服务器部署 mycat数据库中间件
- DSP程序中常出现的EINT、DINT、ERTM、DRTM、EALLOW、EDIS的理解
- HTML 字体图标的引入