Linux进程控制、调度.pdfVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Linux进程控制、调度 进程和程序的区别 程序是存放在磁盘上的一系列代码和数据的可执行映像,是一个静止的实体。 进程是一个执行中的程序。它是动态的实体。 进程四要素 1.有一段程序供其执行。这段程序不一定是某个进程所专有,可以与其他进程共用。 2.有进程专用的内核空间堆栈。 3.在内核中有一个task_struct 数据结构,即通常所说的“进程控制块”。有了这个数据结构, 进程才能成为内核调度的一个基本单位接受内核的调度。 4.有独立的用户空间 进程描述 在Linux 中,线程、进程都使用structtask_struct 来表示,它包含了大量描述进程/线程 的信息,其中比较重要的有: pid_tpid; 进程号,最大值10亿 进程状态 volatile long state /*进程状态*/ 1. TASK_RUNNING 进程正在被CPU 执行,或者已经准备就绪,随时可以执行。当一个进程刚被创建时, 就处于TASK_RUNNING 状态。 2. TASK_INTERRUPTIBLE 处于等待中的进程,待等待条件为真时被唤醒,也可以被信号或者中断唤醒。 3. TASK_UNINTERRUPTIBLE 处于等待中的进程,待资源有效时唤醒,但不可以由其它进程通过信号(signal)或中断唤 醒。 4. TASK_STOPPED 进程中止执行。当接收到SIGSTOP 和SIGTSTP 等信号时,进程进入该状态,接收到 SIGCONT 信号后,进程重新回到TASK_RUNNING。 5. TASK_KILLABLE Linux2.6.25新引入的进程睡眠状态,原理类似于TASK_UNINTERRUPTIBLE,但是可以 被致命信号(SIGKILL)唤醒。 6. TASK_TRACED 正处于被调试状态的进程 7. TASK_DEAD 进程退出时(调用do_exit),state 字段被设置为该状态。 int exit_state /*进程退出时的状态*/ EXIT_ZOMBIE(僵死进程) 表示进程的执行被终止,但是父进程还没有发布waitpid()系统调用来收集有关死亡的进 程的信息。 EXIT_DEAD(僵死撤销状态) 表示进程的最终状态。父进程已经使用wait4()或waitpid()系统调用来收集了信息,因此 进程将由系统删除。 进程描述 struct mm_struct *mm 进程用户空间描述指针,内核线程该指针为空。 unsigned int policy 该进程的调度策略。 int prio 优先级,相当于2.4中goodness()的计算结果,在0--(MAX_PRIO-1)之间取值(MAX_PRIO 定义为140),其中0—(MAX_RT_PRIO-1)(MAX_RT_PRIO定义为100)属于实时进程范围, MAX_RT_PRIO-MX_PRIO-1属于非实时进程。数值越大,表示进程优先级越小 int static_prio 静态优先级,与2.4的nice 值意义相同。nice 值仍沿用Linux 的传统,在-20到19之间变 动,数值越大,进程的优先级越小。nice 是用户可维护的,但仅影响非实时进程的优先级。 进程初始时间片的大小仅决定于进程的静态优先级,这一点不论是实时进程还是非实时进程 都一样,不过实时进程的static_prio不参与优先级计算。nice 与static_prio 的关系如下: static_prio= MAX_RT_PRIO +nice + 20 内核定义了两个宏用来完成这一转换:PRIO_TO_NICE()、NICE_TO_PRIO struct sched_rt_entityrt rt-time_slice 时间片,进程的缺省时间片与进程的静态优先级(在2.4中是nice 值)相关,使用如下公 式得出: MIN_TIMESLICE + ((MAX_TIMESLICE - MIN_TIMESLICE) *(MAX_PRIO-1 - (p)-static_prio)/ (MAX_USER_PRIO-1)) 内核将100-139的优先级映射到200ms-10ms 的时间片上去,优先级数值越大,则分配的时间 片越小。 在Linux中用current 指针指向当前正在运行的进程的task_struct。 调度:从就绪的进程中选出最适合的一个来执行。 1、调度

文档评论(0)

海川电子书城 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档