进程基础

1. 进程分类

进程分为三类:

  1. 交互式进程
    进程与用户交互,平均延迟需要很低,例如键盘和鼠标操作。因为若延迟较高,用户会明显感到系统反应迟钝;
  2. 批处理进程
    这种进程不必与用户交互,经常在后台运行。例如科学计算机程序语言的编译;
  3. 实时进程
    有很强的调度需求,需要有很短的相应时间。典型的如音视频程序;

在Linux中,调度程序可以明确的确认实时进程(如通过静态优先级),但没有办法区分交互式进程和批处理进程,Linux2.6使用的方式是基于历史行为的启发式算法。

2. 进程运行时机

Linux进程是抢占式的,若进程进入TASK_RUNNING状态后,

  1. 内核会检测该进程的动态优先级是否大于current进程,若是则调度程序将中断current进程,选择另一进程运行;
  2. 若当前进程的时间片到期也可以被抢占。
    此时当前进程的TIF_NEED_RESCHED标志被设置,时钟中断处理程序终止时调度程序会调度。

3. 调度算法类型

  • SCHED_FIFO: 先进先出,实时进程
  • SCHED_RR: 时间片轮转,实时进程;
  • SCHED_NORMAL:普通分时进程

4. 进程调度

1. 普通进程调度

每个普通进程有自己的静态优先级,范围是[100, 140),静态优先级用于计算动态优先级等参数,本质上决定了进程的基本时间片。
1)基本时间片
基本时间片公式如下:


屏幕快照 2019-05-22 23.32.05.png

静态优先级越高,其时间片越长。
通常来说较高优先级能获得更长的CPU时间片。


屏幕快照 2019-05-22 23.33.43.png

2)动态优先级和平均睡眠时间
动态优先级计算公式如下:
动态优先级 = max(100, min(静态优先级-bonus+5, 139))

bonus是惩罚值,范围为0到10,值小于5表示惩罚,大于则表示奖赏,同时该值与进程的平均睡眠时间有关。
平均睡眠时间不是过去时间的平均值,而是进程在睡眠状态下的平均纳秒数,进程在运行过程中平均睡眠时间递减。平均睡眠时间小于1s。


平均睡眠时间-bonus

平均睡眠时间也被用于确定一个进程是否为交互式进程的依据:

动态优先级 <= 3*静态优先级/4 + 28
或
bonus-5 >= 静态优先级/4 - 28

上面的公式用于确认进程是否为交互式进程,其中静态优先级/4-28为交互式值。从公式中看出,高优先级进程比低优先级进程更容易成为交互式进程。例如静态优先级为100的进程,若其睡眠时间大于200ms,责备认定为交互式进程。

进程也分为活动进程和过期进程。因为即使高优先级进程获得较高时间片,也不应该让低优先级进程饥饿,当一个进程用完时间片后,应该让低优先级进程投入运行。实现这种机制的方式是调度程序维持了两个集合:

  • 活动进程
    这些进程还未用完时间片,允许它们运行;
  • 过期进程
    这些进程已用完时间片,禁止运行,直到所有活动进程过期再重新分配时间片。

为保持交互式进程的性能,有以下策略:

  1. 用完时间片的批处理进程总是变成过期进程;
  2. 用完时间片的交互式进程通过立即重新分配时间片而总是活动进程
  3. 若最老的过期进程等待很长时间,或过期进程静态优先级大于交互式进程,则将交互式进程移入过期进程。
2. 实时进程

实时进程优先级从1到99,同时实时进程总是活动进程。实时进程仅在以下情况下被取代:

  • 被另一个更高优先级进程抢占;
  • 阻塞进入睡眠;
  • 进程停止或被杀死;
  • 调用sched_yield()放弃CPU;
  • 进程是SCHED_RR且用完时间片。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,258评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,335评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,225评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,126评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,140评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,098评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,018评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,857评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,298评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,518评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,678评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,400评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,993评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,638评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,801评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,661评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,558评论 2 352

推荐阅读更多精彩内容