进程调度时间计算方式

本文介绍了Linux 3.10版本中的CFG调度策略,讲解了进程时间片如何根据权重和就绪队列中所有进程权重之和进行分配。还探讨了nice值与权重的关系,以及CFS调度器如何利用sched_entity和红黑树管理进程的虚拟时间,以选择最优进程运行。
摘要由CSDN通过智能技术生成

最新版linux3.10支持CFG调度策略
CFG调度时分配给每个进程的时间片是多少?
分配给进程的时间 = 总的cpu时间 * 进程的权重/就绪队列(runqueue)所有进程权重之和
CFS调度器针对优先级又提出了nice值的概念,其实和权重是一一对应的关系。nice值就是一个具体的数字,取值范围是[-20, 19]。数值越小代表优先级越大,同时也意味着权重值越大,nice值和权重之间可以互相转换。内核提供了一个表格转换nice值和权重。

const int sched_prio_to_weight[40] = {
/* -20 / 88761, 71755, 56483, 46273, 36291,
/
-15 / 29154, 23254, 18705, 14949, 11916,
/
-10 / 9548, 7620, 6100, 4904, 3906,
/
-5 / 3121, 2501, 1991, 1586, 1277,
/
0 / 1024, 820, 655, 526, 423,
/
5 / 335, 272, 215, 172, 137,
/
10 / 110, 87, 70, 56, 45,
/
15 */ 36, 29, 23, 18, 15,
};

数组的值可以看作是公式:weight = 1024 / 1.25nice计算得到。公式中的1.25取值依据是:进程每降低一个nice值,将多获得10% cpu的时间。公式中以1024权重为基准值计算得来,1024权重对应nice值为0,其权重被称为NICE_0_LOAD。默认情况下,

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值