linux进程调度 同步,Linux进程调度-优先级

从调度的角度,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

阅读(1207) | 评论(0) | 转发(1) |

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值