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
    评论
Linux常用命令 一:关机命令 1:shutdown 语法:shutdown [-efFhknr][-t 秒数][时间][警告信息] 说明:shutdown指令可以关闭所有程序,并依用户的需要,进行重新开机或关机的动作。使用shutdown命令时在系统将要关机前,系统管理员会通知所有登录的使用者系统将要关闭。而且login指令会被冻结,即新的用户不能再登录。这是最安全的一种关机方法,因为在关机之前所有进程都会收到shutdown所发送的信号。shutdown执行它的工作是送信号给init程序,要求它改变runlevel。runlevel 0被用来停机(halt),runlevel 6是用来重新启动(reboot)系统,而runlevel 1则是被用来让系统进入管理工作可以进行的状态;这是预设的,假定没有-h也没有-r参数给shutdown。 参数:  -c  Cancel Current Process取消目前正在执行的关机程序。当执行"shutdown -h 11:50"指令时,只要按Ctrl+c键就可以中断关机的指令。  -f  重新启动时不执行fsck。  -F  重新启动时执行fsck。  -h  将系统关机(halt)。  -k  只是送出信息给所有用户,但不会实际关机。  -n  不调用init程序进行关机,而由shutdown自己进行。不鼓励使用这个选项,而且该选项所产生的后果往往不总是你所预期得到的。  -r  shutdown之后重新启动。  -t<秒数>  送出警告信息和删除信息之间要延迟多少秒。  [时间]  设置多久时间后执行shutdown指令。  [警告信息]  要传送给所有登入用户的信息。 2:reboot 语法:reboot [-dfinw] 说明:执行reboot指令可让系统停止运作,并重新开机。 参数: -d  重新开机时不把数据写入记录文件/var/log/wtmp。本参数具有"-n"参数的效果。 -f  强制重新开机,不调用shutdown指令的功能。 -i  在重开机之前,先关闭所有网络界面。 -n  重开机之前不检查是否有未结束的程序。 -w  仅做测试,并不真的将系统重新开机,只会把重开机的数据写入/var/log目录下的wtmp记录文件。 3:init 语法:init [0-6] 功能说明:转换运行级别(runlevel);init 0为关机,init 6为重启。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值