INFO: task ftest07:1247 blocked for more than 120 seconds 深入探索

这篇博客探讨了Linux内核中遇到的'INFO: task ftest07:1247 blocked for more than 120 seconds'错误信息。作者指出通过运行'echo 0 > /proc/sys/kernel/hung_task_timeout_secs'可以禁用该警告,并强调了解决问题过程中不断探索的重要性。博客表达了对网络上分享知识的前辈们的感激之情,并欢迎大家转载。
摘要由CSDN通过智能技术生成


 

这段时间需要对操作系统做一次ltp测试,主要是跑一下压力测试探探究竟;测试过程中出现了如下信息:
	INFO: task ftest07:1247 blocked for more than 120 seconds.
	"echo  0 > /proc/sys/kernel/hung_task_timeout_secs" disables this message.
	INFO: task ftest07:1248 blocked for more than 120 seconds.
	"echo  0 > /proc/sys/kernel/hung_task_timeout_secs" disables this message.
	INFO: task ftest07:1249 blocked for more than 120 seconds.
	"echo  0 > /proc/sys/kernel/hung_task_timeout_secs" disables this message.
	INFO: task ftest07:125	0 blocked for more than 120 seconds.
	"echo  0 > /proc/sys/kernel/hung_task_timeout_secs" disables this message.

在网上找了一下相关资料,究其原因:
1.首先来看一下kernel 的hung_task(任务挂起)检测机制,我们知道进程一般情况下(实际还有几种另外三种)有三大状
态(R/S/D)分别为运行-TASK_RUNNING(run)、睡眠--可中断TASK_INTERRUPTIBLE(sleep)、睡眠--但是不可中断TASK_UNINTERRUPTIBLE(Deny).
(1)运行:当一个进程在处理机上运行时,则称该进程处于运行状态。处于此状态的进程的数目小于等于处理器的数目,对于单处理机系统,处于
运行状态的进程只有一个。在没有其他进程可以执行时(如所有进程都在阻塞状态),通常会自动执行系统的空闲进程。
(2)就绪:当一个进程获得了除处理机以外的一切所需资源,一旦得到处理机即可运行,则称此进程处于就绪状态。就绪进程可以按多个优先级来划分队列。
例如,当一个进程由于时间片用完而进入就绪状态时,排入低优先级队列;当进程由I/O操作完成而进入就绪状态时,排入高优先级队列。
(3)阻塞:也称为等待或睡眠状态,一个进程正在等待某一事件发生(例如请求I/O而等待I/O完成等)而暂时停止运行,这时即使把处理机分
配给进程也无法运行,故称该进程处于阻塞状态。
所以按照上面的理论描述,我们分析一下:
我们知道进程等待IO时,经常处于D状态,即TASK_UNINTERRUPTIBLE状态,处于这种状态的进程不
处理信号,所以kill不掉,如果进程长期处于D状态,那么肯定不正常,原因可能有二:
1)IO路径上的硬件出问题了,比如硬盘坏了(只有少数情况会导致长期D,通常会返回错误);
2)内核自己出问题了。
这种问题不好定位,而且一旦出现就通常不可恢复,kill不掉,通常只能重启恢复了。
内核针对这种开发了一种hung_task的检测机制,基本原理是:定时检测系统中处于D状态的
进程,如果其处于D状态的时间超过了指定时间(默认120s,可以配置),则打印相关堆栈信
息,也可以通过proc参数配置使其直接panic。
2、hung task相关配置
  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值