百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Linux 是如何调度进程的?

haoteby 2025-01-11 13:23 15 浏览

通过上文《Linux进程在内核眼中是什么样子的?》,可以理解内核关于进程线程的所有管理都是通过一个结构体 —— task_struct。《Linux 进程线程是如何创建的?》也让我们知道了用户态下进程线程是如何创建的,不同的创建方式又有哪些优劣。本文就看下内核态是如何对 task 进行调度的。

调度的发展历史

O(n)算法虽然历史有点悠久,但很有必要研究,是后续O(1)等算法理解的基础。由于O(n)不是本文重点,建议先去网上了解相关知识点。

O(1) 调度器:

O(1) 调度器中引入了per-CPU runqueue的概念。系统中所有的可运行状态的进程首先经过负载均衡模块挂入各个CPU的runqueue,每隔 200ms,处理器都会检查 CPU 的负载是否不均衡,如果不均衡,处理器就会在 CPU 之间进行一次任务均衡操作。然后由主调度器和tick调度器驱动该CPU上的调度行为。每一个优先级的进程被挂入不同链表中。

上图说明了 task 与负载均衡和 runqueue 以及对应调度器之间的关系。每个 runqueue 里又会分为active和expired队列,每个队列中挂载着140个优先级不同的 task 。关于调度器在 runqueue 里的算法实现我们看下面一张图:

来自网络

可以看出2.6 kernel 里有 140 种优先级,所以我们就用长度为 140 的 array 去记录优先级。每个优先级下面用一个 FIFO queue 管理这个优先级下的 process。

那么,我们怎么找到当前最高优先级下面的可执行的 process 呢?如果从 0 开始一直遍历下去,算法虽然不是 O(N),但是是跟优先级多少相关的 O(M),也不能算作 O(1)。在 2.6 scheduler 里,采用 bitarray。它为每种优先级分配一个 bit,如果这个优先级队列下面有 process,那么就对相应的 bit 染色,置为 1,否则置为 0。问题就简化成寻找一个 bitarray 里面最高位是 1 的 bit(left-most bit),这基本上是一条 CPU 指令的事(fls)

大致的思路齐备,我们来整理下步骤:

  1. 在 active bitarray 里,寻找 left-most bit 的位置 x。

  2. 在 active priority array(APA)中,找到对应队列 APA[x]。

  3. 从 APA[x] 中 dequeue 一个 process,dequeue 后,如果 APA[x] 的 queue 为空,那么将 active bitarray 里第 x bit置为 0。

  4. 对于当前执行完的 process,重新计算其 priority,然后 enqueue 到 expired priority array(EPA)相应的队里 EPA[priority]。

  5. 如果 priority 在 expired bitarray 里对应的 bit 为 0,将其置 1。

  6. 如果 active bitarray 全为零,将 active bitarray 和 expired bitarray 交换一下。

CFS 调度器:

虚拟时间:

比如,调度周期是12ms,2个相同优先级的进程A和B,那么每个进程的运行时间各为6ms。倘若进程A,B的优先级nice分别为0和1,那么权重分别是1024和820。它们的关系如下:

权重 = 1024 / 1.25nice(次方)

那么进程A获取的运行时间是12x1024/(1024+820)=6.66ms,进程B获取的运行时间是12x820/(1024+820)=5.34ms。进程A的cpu使用比例是6.66/10=66.6%,进程B的cpu使用比例是5.34/10=53.4%。这里我们看到2个进程的执行时间分别是6.66ms和5.34ms,是不一样的。但是CFS是想让每个进程完全公平调度,这里就引入一个概念——虚拟时间,CFS也是通过虚拟时间相等来保证调度公平的。虚拟时间vriture_runtime和实际时间wall time转换公式如下:

虚拟时间 = 实际时间 * (1024/进程权重) = (调度周期 * 进程权重 / 所有进程总权重) * (1024 / 进程权重) = 调度周期 * 1024 / 所有进程总权重

可以看出虽然进程的权重不同,但是它们的 vruntime增长速度应该是一样的 ,与权重无关。(进程A的虚拟时间=6.66 *(1024/1024)= 6.66ms,进程B的虚拟时间=5.34 *(1024/820)= 6.66ms。这里我们看出虽然进程的优先级不同,但最终的虚拟时间一样。)

总结:谁的vruntime值较小就说明它当前占用cpu的时间较短,受到了“不公平”对待,因此下一个运行进程就是它。这样既能公平选择进程,又能保证高优先级进程获得较多的运行时间。这就是CFS的主要思想了。

就绪队列(runqueue):

CFS维护了一个按照虚拟时间排序的红黑树:

任务存储在以时间为顺序的红黑树中(由 sched_entity 对象表示),对处理器需求最多的任务 (最低虚拟运行时)存储在树的左侧,处理器需求最少的任务(最高虚拟运行时)存储在树的右侧。为了公平,调度器然后选取红黑树最左端的节点调度为下一个以便保持公平性。任务通过将其运行时间添加到虚拟运行时, 说明其占用 CPU 的时间,然后如果可运行,再插回到树中。这样,树左侧的任务就被给予时间运行了,树的内容从右侧迁移到左侧以保持公平。因此,每个可运行的任务都会追赶其他任务以维持整个可运行任务集合的执行平衡。

相关推荐

能跑源码,还提供数据集:这里有一个入门企业级验证码识别项目

机器之心专栏作者:kerlomz网上关于验证码识别的开源项目众多,但大多是学术型文章或者仅仅是一个测试demo,那么企业级的验证码识别究竟是怎样的呢?1.前言网上关于验证么识别的开源项目众多,但大...

kdj源码_kdj源码公式描述

N:=9;M1:=3;M2:=3;...

QT实现抖动文字和滚动文字,附源码

前言不知道大家有没有发现今天的文章有什么不一样,哈哈,我自己胡拼乱凑弄了一个logo,好不好看就先不说了,最起码萌萌哒...当然这不是今天的重点,在做logo的时候,我原本想让文字动起来的,奈何技术有...

我试图通过这篇文章告诉你,这行源码有多牛逼。

你好呀,我是歪歪。这次给你盘一个特别有意思的源码,正如我标题说的那样:看懂这行源码之后,我不禁鼓起掌来,直呼祖师爷牛逼。...

想了解Python源代码加密吗?现总结如下5大加密混淆手段!

我们在进行...

Android系统基础(03) Android系统源码下载

常规官方网站说明:Android源码官方网站为(google你懂的):https://source.android.com官网参考链接,对应的tag(tag是一种标签,我们可以根据tag来判断下载的...

真香,Python爬取B站弹幕原来如此简单,源码已附在文末

B站的弹幕区一直是人才圣地。今天我就用python来手把手教大家爬取B站排行榜热门视频,Python爬取视频也可以如此简单。...

最详细的 maven 教程,可以收藏_maven步骤

链接|cnblogs.com/hzg110/p/6936101.html正文目前所有的项目都在使用maven,可是一直没有时间去整理学习,这两天正好有时间,好好的整理一下。...

Python黑科技-VIP视频破解源码分享

《利用Python制作自己的VIP视频解析软件》想看的电视剧更新了还要充VIP?喜欢的电影你是VIP还得付费?学了Python哪要这些花里胡哨的,打开我自己的VIP付费视频解析软件,想怎么看就怎么看!...

抖音无水印解析网站源码_抖音无水印解析平台

链接:https://share.weiyun.com/59Ah44S密码:hv4dm7上传到主机解压不用安装,直接打开域名就可以了原文地址:https://www.xigsc.com/post/...

「电脑知识」USBOS 3.0 v2022.1.24 超级PE启动维护工具标准增强版

前几天一直在发PE类工具就是为了制作U盘PE启动重装系统教程的,今天小编继续分享有一篇关于pe的之前小编发布过一款微PE工具箱,今天发布另外一个无任何流氓行为功能超级强大虽然体积大了一点,但是这个...

模版网站建设制作的八步流程_模板的网站

  模版网站比较简单,一般我们按照如下流程就可以制作出来。  一、网站定位:  在建站之前,一定要了解你要建的网站是什么。你必须考虑你网站的标题(关键词)、网站描述以及你想要建立的网站。  二、选择域...

求职季必备,这几个免费的个人简历模板网站,你可千万不要错过!

晃晃悠悠又到了春招的季节,相信一定有很多小伙伴趁着这个金三银四求职季,四处投递简历。这时候一个亮眼优秀的简历,可以很好的祝你吸引HR的注意。今天就把我珍藏很久的5个免费简历模板网站分享给大家,简历模板...

简约时尚作品博客商店网站HTML5模板源码

Meduza是简约时尚和现代的博客HTML模板,带商店电商元素的博客页面。考虑所有的作品集网站需求页可以设计一个旅游网站。原生响应设计HTML5和CSS3(台式机、平板电脑、手机…)简单,干净的和专业...

13 款免费样机网站合集,UI设计、产品设计、VI设计全都有!

俗话说得好,人靠衣装,在作完设计后不少设计师都会为自己的作品套一个「样机」好让设计看过去更加高端大气上档次!今天,我就总结了无论是UI设计、包装设计、服装设计、品牌设计、logo设计,都能用到...