Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1331003
  • 博文数量: 175
  • 博客积分: 2743
  • 博客等级: 少校
  • 技术积分: 4024
  • 用 户 组: 普通用户
  • 注册时间: 2010-12-30 01:41
文章分类

全部博文(175)

文章存档

2015年(1)

2013年(53)

2012年(71)

2011年(50)

分类: LINUX

2013-04-17 16:06:33

  从调度的角度,Linux把进程分成140个优先等级,其中0级到99级是分给实时进程的,100级到139级是分给非实时进程的。每个优先等级都有 一个运行对列,这样就有140个运行队列。级数越小优先度越高。调度程序从0级到139级依次询问每个运行队列是否有可执行进程。询问的方法是通过访问一 个bitmap,这个位图共有160bits,前140位与140个运行队列一一对应,后20位空闲。在每个运行队列里又把进程分成两组队 列,active队列和expired队列。active队列相当于前面说的那个圆盘,里面的进程是被分配了时间片的。expired队列相当于圆盘外的 “替补席”。一般来说,active队列里的进程用完其时间片后,就被送到expired队列里(也可能由于要和某个外设同步而被直接送到“休息室”-- 由可执行状态变成等待状态)。当active队列里的进程都被送出去的时候,就把active队列和expired队列互换一下,原来的active队列 变成expired队列,原来的expired队列变成active队列。这就是Linux进程调度的基本思路。
    Linux进程的优先级有两种,静态优先级和动态优先级。
    静态优先级是初始优先级,它决定时间片的大小。
        时间片大小 = (140 - 静态优先级) X 20 ;( 静态优先级
        时间片大小 = (140 - 静态优先级) X 5 ;( 静态优先级 >= 120)
    和静态优先级有关的一个变量叫做nice。进程外部可以通过调整nice值改变静态优先级。
        静态优先级 = 120 - nice值
    动态优先级是在调度的过程中不断变化的。它决定该进程被送到140个运行队列中的哪一个。
        动态优先级 = max(100, min(静态优先级 - bonus + 5, 139))
    和动态优先级有关的一个变量叫做bonus。动态优先级所谓的“动态”就体现在bonus的变化上。bonus的值和进程的睡眠时间反相关,睡眠时间越长 bonus值越大,睡眠时间越短bonus值越小。bonus的取值范围是0-10。另外bonus还有一个作用就是可以作为区分交互进程和批处理进程的 标准。
        当 bonus - 5 >=静态优先级 / 4- 28 时,该进程被看作交互进程。
        当 bonus - 5
阅读(2796) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~