Linux 核心--5.Linux进程

第四章 进程管理

本章重点讨论Linux内核如何在系统中创建、管理以及删除进程 。

进程在操作系统中执行特定的任务 。而程序是存储在磁盘上包含可执行机器指令和数据的静态实体 。进程或者任务是处于活动状态的计算机程序 。

进程是一个随执行过程不断变化的实体 。和程序要包含指令和数据一样 , 进程也包含程序计数器和所有CPU寄存器的值 , 同时它的堆栈中存储着如子程序参数、返回地址以及变量之类的临时数据 。当前的执行程序 , 或者说进程 , 包含着当前处理器中的活动状态 。Linux是一个多处理操作系统 。进程具有独立的权限与职责 。如果系统中某个进程崩溃 , 它不会影响到其余的进程 。每个进程运行在其各自的虚拟地址空间中 , 通过核心控制下可靠的通讯机制 , 它们之间才能发生联系 。

进程在生命期内将使用系统中的资源 。它利用系统中的CPU来执行指令 , 在物理内存来放置指令和数据 。使用文件系统提供的功能打开并使用文件 , 同时直接或者间接的使用物理设备 。Linux必须跟踪系统中每个进程以及资源 , 以便在进程间实现资源的公平分配 。如果系统有一个进程独占了大部分物理内存或者CPU的使用时间 , 这种情况对系统中的其它进程是不公平的 。

系统中最宝贵的资源是CPU , 通常系统中只有一个CPU 。Linux是一个多处理操作系统 , 它最终的目的是:任何时刻系统中的每个CPU上都有任务执行 , 从而提高CPU的利用率 。如果进程个数多于CPU的个数 , 则有些进程必须等待到CPU空闲时才可以运行 。多处理是的思路很简单;当进程需要某个系统资源时它将停止执行并等待到资源可用时才继续运行 。单处理系统中 , 如DOS , 此时CPU将处于空等状态 , 这个时间将被浪费掉 。在多处理系统中 , 因为可以同时存在多个进程 , 所以当某个进程开始等待时 , 操作系统将把CPU控制权拿过来并交给其它可以运行的进程 。调度器负责选择适当的进程来运行 , Linux使用一些调度策略以保证CPU分配的公平性 。

Linux支持多种类型的可执行文件格式 , 如ELF , JAVA等 。由于这些进程必须使用系统共享库 , 所以对它们的管理要具有透明性 。


4.1Linux进程
为了让Linux来管理系统中的进程 , 每个进程用一个task_struct数据结构来表示(任务与进程在Linux中可以混用) 。数组task包含指向系统中所有task_struct结构的指针 。

这意味着系统中的最大进程数目受task数组大小的限制 , 缺省值一般为512 。创建新进程时 , Linux将从系统内存中分配一个task_struct结构并将其加入task数组 。当前运行进程的结构用current指针来指示 。

Linux还支持实时进程 。这些进程必须对外部时间作出快速反应(这就是“实时”的意思) , 系统将区分对待这些进程和其他进程 。虽然task_struct数据结构庞大而复杂 , 但它可以分成一些功能组成部分:


State
进程在执行过程中会根据环境来改变state 。Linux进程有以下状态:
Running
进程处于运行(它是系统的当前进程)或者准备运行状态(它在等待系统将CPU分配给它) 。
Waiting
进程在等待一个事件或者资源 。Linux将等待进程分成两类;可中断与不可中断 。可中断等待进程可以被信号中断;不可中断等待进程直接在硬件条件等待 , 并且任何情况下都不可中断 。
Stopped
进程被停止 , 通常是通过接收一个信号 。正在被调试的进程可能处于停止状态 。
Zombie
这是由于某些原因被终止的进程 , 但是在task数据中仍然保留task_struct结构 。它象一个已经死亡的进程 。

推荐阅读