linux进程的状态转换过程是,Linux 把进程为D(不可中断进程)转换成其他状态

问题现象:当前集群跑hadoop的时候,,任务失败,但是跑任务的容器没有正常退出,显示一大堆的YarcChild进程,,more /proc/进程/status   查看其状态,进程为D(disk sleep),当使用ps  查看所有D进程状态的时候,执行ps这个命令的进程也变成了D状态,,尬的一批。所谓D状态就是不可中断的状态,处于该状态下的进程不接受任何发给他的信号,通常导致该情况产生的原因是由于长时间等待IO导致的,一般的处理方法是reboot,但是生成环境服务器,还是大量的机器有处于D状态的进程,,进行reboot是不可取的。

1、在Linux下创建一个killd.c文件,该文件的信息如下:

#include

#include /*Needed by all modules*/

#include

#include //for_each_process

MODULE_LICENSE("BSD");

static int pid = -1;

module_param(pid, int, S_IRUGO);

static int killd_init(void)

{

struct task_struct * p;

printk(KERN_ALERT "killd: force D status process to death/n");

printk(KERN_ALERT "killd: pid=%d/n", pid);

//read_lock(&tasklist_lock);

for_each_process(p){

if(p->pid == pid){

printk("killd: found/n");

set_task_state(p, TASK_STOPPED);

printk(KERN_ALERT "killd: aha, dead already/n");

return 0;

}

}

printk("not found");

//read_unlock(&tasklist_lock);

return 0;

}

static void killd_exit(void)

{

printk(KERN_ALERT "killd: bye/n");

}

module_init(killd_init);

module_exit(killd_exit);

2、同路径下创建Makefile文件,内容如下:

obj-m := killd.o

all :

$(MAKE) -C /lib/modules/$(shell uname -r)/build M=$(PWD) modules //最前面的空格必须是tab键生产,否则编译产生错误Makefile:3: *** missing separator.  Stop.

clean:

$(MAKE) -C /lib/modules/$(shell uname -r)/build M=$(PWD) clean

3、在当前目录下执行make

执行报错,如下:

make -C /lib/modules/3.10.-957.5..el7.x86_64/build M=/data1/c-make modules

make: *** /lib/modules/3.10.-957.5..el7.x86_64/build: No such file or directory. Stop.

make: *** [all] Error

提示没有文件

4、进入/usr/src/kernels/下看有没有相应的内核开发包,没有,就安装,若有跳过第一步

UNAME=$(uname -r)

yum install gcc kernel-devel-${UNAME%.*}

正常情况下安装完成以后就可以正常编译了,如果不行,创建软连接

ln -s /usr/src/kernels/3.10.-957.5..el7.x86_64/ /lib/modules/3.10.-957.5..el7.x86_64/build/

5、插入模块的时候提供D状态的进程号,就可以将其转换为t状态,使用普通kill就可以杀死。

sudo insmod ./killd.ko pid=

借鉴:

Linux下使用xargs将多行文本转换成一行并用tr实现逗号隔开

准备: cat test.txt 示例: cat test.txt | xargs 可以看出得到的字符串为空格隔开的. 再把上面的字符串用逗号隔开,可以使用tr命令进行空格的替换 cat test.t ...

linux中断--进程上下文和中断上下文

一.前言 中断发生以后,CPU跳到内核设置好的中断处理代码中去,由这部分内核代码来处理中断.这个处理过程中的上下文就是中断上下文. 为什么可能导致睡眠的函数都不能在中断上下文中使用呢? 首先睡眠的含义 ...

linux 用户态和内核态以及进程上下文、中断上下文 内核空间用户空间理解

1.特权级         Intel x86架构的cpu一共有0-4四个特权级,0级最高,3级最低,ARM架构也有不同的特权级,硬件上在执行每条指令时都会对指令所具有的特权级做相应的检查.硬件已经提 ...

Linux 性能分析调优 (四)——案例篇:系统中出现大量不可中断进程和僵尸进程怎么办

之前讲到 CPU 使用率的类型.除了上一节提到的用户 CPU 之外,它还包括系统 CPU(比如上下文切换).等待 I/O 的 CPU(比如等待磁盘的响应)以及中断 CPU(包括软中断和硬中断)等. 在 ...

linux系统编程之进程(二):进程生命周期与PCB(进程控制块)

本节目标: 进程状态变迁 进程控制块 进程创建 进程撤消 终止进程的五种方法 一,进程状态变迁 进程的三种基本状态 就绪(Ready)状态 当进程已分配到除CPU以外的所有必要的资源,只要获得处理机便 ...

《Linux内核分析》第八周 进程的切换和系统的一般执行过程

[刘蔚然 原创作品转载请注明出处 MOOC课程http://mooc.study.163.com/course/USTC-1000029000] WEEK EIGHT ...

linux第1天 fork exec 守护进程

概念方面 文件是对I/O设备的抽象表示.虚拟存储器是对主存和磁盘I/O设备的抽象表示.进程则是对处理器.主存和I/O设备的抽象表示 中断 早期是没有进程这个概念,当出现中断技术以后才出现进程这个概念 ...

Linux下进程描述(1)—进程控制块

进程概念介绍 进程是操作系统对运行程序的一种抽象. • 一个正在执行的程序: • 一个正在计算机上执行的程序实例: • 能分配给处理器并由处理器执行的实体: • 一个具有普以下特征的活动单元:一组指令 ...

linux调度器源码分析 - 新进程加入(三)

本文为原创,转载请注明:http://www.cnblogs.com/tolimit/ 引言 之前的文章已经介绍了调度器已经初始化完成,现在只需要加入一个周期定时器tick驱动它进行周期调度即可,而加 ...

随机推荐

[转]表结构设计器EZDML介绍说明(包含修改配置文件,修改文本字段属性)

超轻量级的表结构设计工具,这是一个数据库建表的小软件,可快速的进行数据库表结构设计,建立数据模型.类似大家常用的数据库建模工具如PowerDesigner.ERWIN.ER-Studio和Ration ...

学习docker

虚拟机下Ubuntu环境 1.sudo apt-get update 2.sudo apt-get install docker.io 3.在daocloud(http://www.daocloud. ...

js鲸鱼

css+div

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值