快速业务通道

TASK_KILLABLE:Linux 中的新进程状态

作者 佚名技术 来源 Linux系统 浏览 发布时间 2012-05-10
任务.但需要注意的一种情况是,对不可中断睡眠模式的进程的唤醒呼叫可能会某些原因不会发生,这会使进程无法被终止,从而最终引发问题,惟一的解决方法就是重启系统.一方面,您需要考虑一些细节,不这样做会在内核端和用户端引入 bug.另一方面,您可能会生成永远不会停止的进程(被阻塞且无法终止的进程).

现在,我们在内核中实现了一种新的睡眠方法!

新睡眠状态:TASK_KILLABLE

Linux Kernel 2.6.25 引入了一种新的进程睡眠状态,TASK_KILLABLE:当进程处于这种可以终止的新睡眠状态中,它的运行原理类似于 TASK_UNINTERRUPTIBLE,只不过可以响应致命信号.清单 1 给出了内核 2.6.18 与内核 2.6.26 进程状态(定义在 include/linux/sched.h 中)之间的比较:


清单 1. 2.6.18 和 2.6.26 进程状态之间的比较

Linux Kernel 2.6.18                    Linux Kernel 2.6.26

=================================      ===================================

#define TASK_RUNNING            0      #define TASK_RUNNING            0

#define TASK_INTERRUPTIBLE      1      #define TASK_INTERRUPTIBLE      1

#define TASK_UNINTERRUPTIBLE    2      #define TASK_UNINTERRUPTIBLE    2

#define TASK_STOPPED            4      #define __TASK_STOPPED          4

#define TASK_TRACED             8      #define __TASK_TRACED           8

/* in tsk->exit_state */            /* in tsk->exit_state */

#define EXIT_ZOMBIE             16     #define EXIT_ZOMBIE             16

#define EXIT_DEAD               32     #define EXIT_DEAD               32

/* in tsk->state again */           /* in tsk->state again */

#define TASK_NONINTERACTIVE     64     #define TASK_DEAD               64

                                    #define TASK_WAKEKILL           128

注意,状态 TASK_INTERRUPTIBLE 和 TASK_UNINTERRUPTIBLE 并未修改. TASK_WAKEKILL 用于在接收到致命信号时唤醒进程.

清单 2 展示了状态 TASK_STOPPED 和 TASK_TRACED 的修改之处(以及 TASK_KILLABLE 的定义):


清单 2. 内核 2.6.26 中的新状态定义

#define TASK_KILLABLE   (TASK_WAKEKILL | TASK_UNINTERRUPTIBLE)

#define TASK_STOPPED    (TASK_WAKEKILL | __TASK_STOPPED)

#define TASK_TRACED     (TASK_WAKEKILL | __TASK_TRACED)

换句话说,TASK_UNINTERRUPTIBLE TASK_WAKEKILL = TASK_KILLABLE.

使用 TASK_KILLABLE 的新内核 API

让我们来看看这种新状态中的新函数.

●int wait_event_killable(wait_queue_t queue, condition);
●该函数定义在 include/linux/wait.h 中;它将处于可终止睡眠状态的调用进程置于 queue 中,直到 condition 等于 true.
●long schedule_timeout_killable(signed long timeout);
●该函数定义在 kernel/timer.c 中;该例程主要用于将当前任务的状态设置为 TASK_KILLABLE 并调用 schedule_timeout(),它用于让调用任务睡眠 timeout 个 jiffies.(在 UNIX 系统中,jiffy 主要表示两个连续时钟计时单元之间的时间.
●int wait_for_completion_killable(struct completion *comp);
●此例程定义在 kernel/sched.c 中,它用于等待进程在事件完成后变为可终止状态.如果没有等待的致命信号,该函数将调用 schedule_timeout() 维持 MAX_SCHEDULE_TIMEOUT(指定为等于 LONG_MAX)个 jiffies 时间.
●int mutex_lock_killable(struct mutex *lock);
●定义在 kernel/mutex.c 中,该例

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号