首页
学习
活动
专区
工具
TVP
发布

Linux 内核】调度 ⑦ ( 调度类型 | 停机调度 stop_sched_class | 限期调度 dl_sched_class | 实时调度 | 公平调度 | 空闲调度 )

文章目录 一、调度类型 二、调度类型源码定义 三、停机调度 ( stop_sched_class ) 四、限期调度 ( dl_sched_class ) 五、实时调度 ( rt_sched_class...) 六、公平调度 ( fair_sched_class ) 七、空闲调度 ( idle_sched_class ) 一、调度类型 ---- 在 Linux 内核中 , sched_class 调度...: 公平调度 ; idle_sched_class : 空闲调度 ; 上述每种 " 调度 " 都有自己的 调度策略 ; 调度 优先级 由高到低排列为 : 停机调度 > 限期调度 > 实时调度...> 公平调度 > 空闲调度 二、调度类型源码定义 ---- 调度类型 , 定义在 Linux 内核源码 linux-5.6.18\kernel\sched\sched.h 头文件中的 1792...每个 CPU 上都有一个 空闲线程 , 该空闲线程称为 0 号线程 ; 空闲调度 优先级最低 , 只有在 其它类型的调度进程都执行完毕后 , 才会执行 空闲调度 对应的进程 ;

1.3K20

Linux 内核】CFS 调度 ④ ( 调度子系统组件模块 | 主调度、周期性调度 | 调度 )

文章目录 一、调度子系统组件模块 二、主调度、周期性调度 三、调度 一、调度子系统组件模块 ---- 调度 需要对 被调度的进程 进行 排序 和 调度管理 , 进程管理过程需要 调度 的 组件模块..." 选择不同的 调度 , 可选的调度参考 【Linux 内核】调度 ⑦ ( 调度类型 | 停机调度 stop_sched_class | 限期调度 dl_sched_class | 实时调度...| 公平调度 | 空闲调度 ) 博客 , 在 Linux 内核中 , sched_class 调度 分为以下 5 种类型 : stop_sched_class : 停机调度 ; dl_sched_class...: 限期调度 ; rt_sched_class : 实时调度 ; fair_sched_class : 公平调度 ; idle_sched_class : 空闲调度 ; 每个 调度...都负责 调度管理 若干进程 , 调度 用于 判断 下一步要运行哪个进程 ,

3.1K10
您找到你想要的搜索结果了吗?
是的
没有找到

linux 进程调度(下) -- 调度演进

引言 通过此前的两篇文章,我们系统介绍了 linux 操作系统中的调度算法与其演进: linux 操作系统的进程调度(上) -- 进程调度的基本概念 linux 操作系统的进程调度(中) -- 进程调度算法的演进...本文,我们就来介绍 Linux 操作系统实际使用的进程调度以及它们的演进。...O(n) 调度 在早期的 linux 操作系统中,2.4 版本到 2.6 版本之间,linux 采用了实现起来十分简单的 O(n) 调度。...O(1) 调度linux 内核采用 O(n) 调度的 4 年后,Linux2.6.0 采纳了 Rad Hat 公司设计的 O(1) 调度算法,这是一个基于上一篇文章中介绍的多级反馈队列算法的调度实现...CFS 调度 由于 O(1) 调度的上述问题,很快在 Linux 2.6.23 版本,就有一款新的调度 -- CFS 被内核采用,它是由匈牙利程序员 Ingo Molnar 在澳大利亚外科医生 Con

2K20

Linux 内核】调度 ① ( 调度概念 | 调度目的 | 调度主要工作 | 调度位置 | 进程优先级 | 抢占式调度 | Linux 进程状态 | Linux 内核进程状态 )

文章目录 一、调度 0、调度概念 1、调度目的 2、调度主要工作 3、调度位置 4、进程优先级 5、抢占式调度 二、Linux 内核进程状态 API 简介 三、Linux 进程状态 一、调度...---- 0、调度概念 Linux 内核的 " 进程调度 " 是按照 设计好的调度算法 安排的 , 该算法对应的功能模块 称为 " 调度 " , 英文名称是 Scheduler ; 1、调度目的...进程调度 目的是 最大限度利用 CPU 资源 , 也就是 CPU 时间片 ; 2、调度主要工作 " 调度 " 主要的工作 : ① 就绪 -> 执行 : 选择 " 就绪状态 " 的进程执行 ; (..." , 主要是 " 就绪状态 " 与 " 执行状态 " 这两个状态之间相互切换 ; 3、调度位置 调度 在 如下的 进程状态图 中的位置是 " 就绪状态 " 与 " 运行状态 " 之间 ; 就绪状态..." 抢占式调度 " 概念 : 如果 " 调度 " 支持 " 就绪状态 " 与 " 运行状态 " 之间可以相互转换 , 则该调度称为 " 抢占式调度 " ; 二、Linux 内核进程状态 API

5.4K20

Linux 进程调度之schdule主调度

至于CFS调度算法的实现后面后专门写一篇文章,这里只要记住调度时选择一个优先级最高的任务执行 一、调度单位简介 1.1 task_struct 结构体简介 对于Linux内核来说,调度的基本单位是任务,...,调度只会选择在该状态下的任务进行调度。...(2)sched_class :表示任务所属的调度,我们这里只讲CFS调度。 // kernel/sched/sched.h struct sched_class { .........在这里我只讨论普通任务的调度,因为linux大部分情况下都是在运行普通任务,普通任务选择的调度是CFS完全调度。 在调度时,调度去 CFS 运行队列找是否有任务需要运行。...直接调用主调度schdule函数的场景有3种: (1)当前进程需要等待某个条件满足才能继续运行时,调用一个wait_event()函数将自己的状态设为TASK_INTERRUPTIBLE或者TASK_UNINTERRUPTIBLE

1.7K20

调度简介,以及Linux调度策略

调度是CPU时间的管理员。Linux调度需要负责做两件事:一件事是选择某些就绪的进程来执行;另一件事是打断某些执行中的进程,让它们变回就绪状态。不过,并不是所有的调度都有第二个功能。...当计算机中有大量进程在运行时,这个调度的性能将会被大大降低。也就是说,O(n)调度没有很好的可拓展性。O(n)调度Linux 2.6之前使用的进程调度。...O(1)调度会根据平均休眠时间来调整进程优先级。该调度假设那些休眠时间长的进程是在等待用户互动。这些互动的进程应该获得更高的优先级,以便给用户更好的体验。...完全公平调度 从2007年发布的Linux 2.6.23版本起,完全公平调度(CFS,Completely Fair Scheduler)取代了O(1)调度。...以上就是调度的基本原理,以及Linux用过的几种调度策略。调度可以更加合理地把CPU时间分配给进程。现代计算机都是多任务系统,调度在多任务系统中起着顶梁柱的作用。

2K21

Linux O(1)调度

O(n)调度的种种问题,linux内核社区则在2.6内核版本引入了O(1)调度,当然了引入的目的也正是要解决O(n)调度面临的问题。...我们这片文章以Linux2.6.2版本来学习,在Linux内核文档中有一篇关于O(1)调度的目的,如何设计的,以及实现有一个详细的介绍:sched-design.txt文档,有兴趣的可以去阅读。...O(1)调度的工作原理 ?...总结: O(1)调度的引入主要是为了解决O(n)调度的不足 O(1)调度在赏罚机制上比O(n)调度考虑的因素比较多,不再时像O(1)那样直接考时间片的大小来调度 但是O(n)和O(1)调度算法上核心还是通过判断一个进程的行为...当然了时代还是要前进的,O(n)和O(1)调度是为CFS调度出现地提供了很好的环境。

2.8K21

Linux O(n)调度

前面我们学习了调度的设计需要关注的几个点,在这里复习下: 吞吐量(对应的是CPU消耗型进程) 响应速度(对应的是IO消耗型进程) 公平性,确保每个进程都可以有机会运行到 移动设备的功耗 Linux调度的设计...经常睡眠的进程尝试增大下优先级,经常长占CPU的适当减少优先级 本节我们先来学习Linux早期的调度算法的设计,先从最早的调度算法开始,此调度时间复杂度是O(n),所以也可以称为O(n)调度算法。...我们选择的内核版本是linux-2.4.19。 O(n)调度的实现原理 O(n)代表的是寻找一个合适的进程的时间复杂度。...时间片的计算 O(n)调度采用的是TICK的方式,根据对应进程的nice值来计算对应的时间片的。...总之O(n)调度有很多问题,不过有问题肯定要解决的。所以在Linux2.6引入了O(1)的调度

3.3K20

Linux 内核】调度 ② ( sched_class 调度结构体源码 | 源码路径 linux-5.6.18kernelschedsched.h )

文章目录 一、调度 二、sched_class 调度结构体 一、调度 ---- 上一篇博客 【Linux 内核】调度 ( 调度概念 | 调度目的 | 调度主要工作 | 调度位置 | 进程优先级...| 抢占式调度 | Linux 进程状态 | Linux 内核进程状态 ) 介绍了 " 调度 " 概念 , Linux 内核的 " 进程调度 " 是按照 设计好的调度算法 安排的 , 该算法对应的功能模块...称为 " 调度 " , 英文名称是 Scheduler ; " 调度 " 可以 切换 " 进程状态 " , 主要是 " 就绪状态 " 与 " 执行状态 " 这两个状态之间相互切换 ; " 抢占式调度..." 概念 : 如果 " 调度 " 支持 " 就绪状态 " 与 " 运行状态 " 之间可以相互转换 , 则该调度称为 " 抢占式调度 " ; 二、sched_class 调度结构体 ---- Linux...内核源码 linux-5.6.18\kernel\sched\sched.h 中 , 定义的 struct sched_class 调度结构体 , 就是 " 调度 " 对应的 ; struct

53330

Linux进程核心调度之主调度schedule--Linux进程的管理与调度(十九)

return p; } /* 进程中所有的调度, 是通过next域链接域链接在一起的 * 调度的顺序为stop -> dl -> rt -> fair -> idle..., 依次执行pick_next_task操作选择最优的进程 它会从优先级最高的sched_class_highest(目前是stop_sched_class)查起, 依次按照调度的优先级从高到低的顺序调用调度对应的...pick_next_task函数用以查找对应调度下的最优进程, 其定义如下所示 调度 pick_next策略 pick_next_task_fair函数 stop_sched_class - kernel..., 也就是说多数情形下, 我们的linux中进程全是cfs调度的 而likely这个宏业表明了这点, 这也是gcc内建的一个编译选项, 它其实就是告诉编译表达式很大的情况下为真, 编译可以对此做出优化...cfs调度的普通非实时进程, 则直接用cfs调度, 如果无程序可调度调度idle进程 否则从优先级最高的调度sched_class_highest(目前是stop_sched_class)开始依次遍历所有调度

3.5K31

Linux 内核】实时调度 ③ ( 实时调度 rt_sched_class 源码 | 调度 sched_class 源码 )

| 实时调度 | 公平调度 | 空闲调度 ) ---- 在 linux-5.6.18\include\linux\sched.h 头文件中 task_struct " 进程描述符 " 结构体 中定义的...sched_class 字段 , 表示该进程所属的调度 ; const struct sched_class *sched_class; 源码地址 : linux-5.6.18\include\linux...\sched.h#680 上述可设置的调度参考 【Linux 内核】调度 ⑦ ( 调度类型 | 停机调度 stop_sched_class | 限期调度 dl_sched_class | 实时调度...| 公平调度 | 空闲调度 ) 博客 , 在 Linux 内核中 , sched_class 调度 分为以下 5 种类型 : stop_sched_class : 停机调度 ; dl_sched_class...调度 结构体 类型 的 , 在 Linux 内核源码的 linux-5.6.18\kernel\sched\rt.c 源文件中定义 ; const struct sched_class rt_sched_class

69110

Linux进程调度概述--Linux进程的管理与调度(十五)

CFS调度 linux-2.6~至今 4 Linux调度设计 4 Linux调度设计 2个调度 可以用两种方法来激活调度 一种是直接的, 比如进程打算睡眠或出于其他原因放弃CPU 另一种是通过周期性的机制...)) 并且每个调度包括两个内容:调度框架(其实质就是两个函数框架)及调度 6种调度策略 linux内核目前实现了6种调度策略(即调度算法), 用于对不同类型的进程进行调度, 或者支持某些特殊的功能...基于Earliest Deadline First (EDF) 调度算法 DL linux内核实现的6种调度策略, 前面三种策略使用的是cfs调度,后面两种使用rt调度, 最后一个使用DL调度...也存储了其对应的调度实体标识 linux实现了6种调度策略, 依据其调度策略的不同实现了5个调度, 一个调度可以用一种或者多种调度策略调度某一进程, 也可以用于特殊情况或者调度特殊功能的进程....5种调度为什么只有3种调度实体 正常来说一个调度应该对应一调度实体, 但是5种调度却只有了3种调度实体?

3.4K20

Linux 内核】CFS 调度 ① ( CFS 完全公平调度概念 | CFS 调度虚拟时钟 Virtual Runtime 概念 | 四种进程优先级 | 五种调度 )

文章目录 一、CFS 调度概念 ( 完全公平调度 ) 二、CFS 调度虚拟时钟概念 ( Virtual Runtime ) 三、进程优先级 ( 调度优先级 | 静态优先级 | 正常优先级 | 实时优先级...) 四、调度 ( 停机调度 | 限期调度 | 实时调度 | 公平调度 | 空闲调度 ) 一、CFS 调度概念 ( 完全公平调度 ) ---- CFS 调度 ( Completely...( 停机调度 | 限期调度 | 实时调度 | 公平调度 | 空闲调度 ) ---- 在 linux-5.6.18\include\linux\sched.h 头文件中 task_struct...-5.6.18\include\linux\sched.h#680 上述可设置的调度参考 【Linux 内核】调度 ⑦ ( 调度类型 | 停机调度 stop_sched_class | 限期调度...dl_sched_class | 实时调度 | 公平调度 | 空闲调度 ) 博客 , 在 Linux 内核中 , sched_class 调度 分为以下 5 种类型 : stop_sched_class

1.7K40

Linux核心调度之周期性调度scheduler_tick--Linux进程的管理与调度(十八)

对于普通进程则采用CFS完全公平调度进行调度 1.3 linux调度的演变 table th:nth-of-type(1){ width: 20%; } 字段 版本 O(n)的始调度算法 linux...-0.11~2.4 O(1)调度 linux-2.5 CFS调度 linux-2.6~至今 1.4 Linux调度组成 2个调度 可以用两种方法来激活调度 一种是直接的, 比如进程打算睡眠或出于其他原因放弃...)或核心调度(core scheduler)) 并且每个调度包括两个内容:调度框架(其实质就是两个函数框架)及调度 6种调度策略 linux内核目前实现了6中调度策略(即调度算法), 用于对不同类型的进程进行调度...则在系统空闲时调用idle进程. 5个调度 而依据其调度策略的不同实现了5个调度, 一个调度可以用一种种或者多种调度策略调度某一进程, 也可以用于特殊情况或者调度特殊功能的进程..... 3 周期性调度的激活 3.1 定时周期性的激活调度 定时Linux提供的一种定时服务的机制.

2.5K20

Linux进程调度的设计--Linux进程的管理与调度(十七)

基于Earliest Deadline First (EDF) 调度算法 DL linux内核实现的6种调度策略, 前面三种策略使用的是cfs调度,后面两种使用rt调度, 最后一个使用DL调度...2.3 5个调度 而依据其调度策略的不同实现了5个调度, 一个调度可以用一种种或者多种调度策略调度某一进程, 也可以用于特殊情况或者调度特殊功能的进程....也存储了其对应的调度实体标识 linux实现了6种调度策略, 依据其调度策略的不同实现了5个调度, 一个调度可以用一种或者多种调度策略调度某一进程, 也可以用于特殊情况或者调度特殊功能的进程....2.7 5种调度为什么只有3种调度实体? 正常来说一个调度应该对应一调度实体, 但是5种调度却只有了3种调度实体?...参照 linux调度源码分析 - 概述(一) 通过的调度策略对象–调度 linux下每个进程都由自身所属的调度进行管理, sched_class结构体表示调度, 调度提供了通用调度和各个调度之间的关联

3.4K41

Linux 内核】CFS 调度 ② ( CFS 调度 “ 权重 “ 概念 | CFS 调度调度实例 | 计算进程 “ 实际运行时间 “ )

文章目录 一、CFS 调度 " 权重 " 概念 二、CFS 调度调度实例 ( 计算进程 " 实际运行时间 " ) 一、CFS 调度 " 权重 " 概念 ---- CFS 调度 ( Completely...Fair Scheduler ) " 完全公平调度 " , 实际运行过程中 , 会涉及到 具有 不同 " 进程优先级 " 的 进程 之间的调度 , 有些进程 优先级高 , 有些进程 优先级低 ,...为了避免 优先级低 的进程 始终无法得到 CPU 时间 执行 , 向每个进程提供 公平 调度 , CFS 调度 引入了 " 权重 " 概念 , CFS 使用 " 权重 " 值 , 替代 进程的 优先级..., 不同 " 进程优先级 " 的进程 会按照 权重比例 , 分配 CPU 的执行时间 ; 二、CFS 调度调度实例 ( 计算进程 " 实际运行时间 " ) ---- 有 2 个进程 A 和 B...大小 , 则 进程 在 CPU 上执行的进程 可获取到的 CPU 时间 计算公式如下 : \rm 进程获取的CPU 时间 = 调度区 \times \cfrac{进程权重}{所有进程的权重之和}

1.7K30

如何更改 Linux 的 IO 调度

Linux 的 I/O 调度是一个以块式 I/O 访问存储卷的进程,有时也叫磁盘调度。...Linux I/O 调度的工作机制是控制块设备的请求队列:确定队列中哪些 I/O 的优先级更高以及何时下发 I/O 到块设备,以此来减少磁盘寻道时间,从而提高系统的吞吐量。...目前 Linux 上有如下几种 I/O 调度算法: noop – 通常用于内存存储的设备。 cfq – 完全公平调度。进程平均使用IO带宽。...Deadline – 针对延迟的调度,每一个 I/O,都有一个最晚执行时间。 Anticipatory – 启发式调度,类似 Deadline 算法,但是引入预测机制提高性能。... anticipatory deadline [cfq] 如何改变硬盘设备 I/O 调度 (adsbygoogle = window.adsbygoogle || []).push(

4.4K20

Linux CFS调度之唤醒抢占--Linux进程的管理与调度(三十)

) pick_next_task_fair 主调度会按照如下顺序调度 schedule -> __schedule -> 全局pick_next_task全局的pick_next_task函数会从按照优先级遍历所有调度的...pick_next_task函数, 去查找最优的那个进程, 当然因为大多数情况下, 系统中全是CFS调度的非实时进程, 因而linux内核也有一些优化的策略 一般情况下选择红黑树中的最左进程left作为最优进程完成调度...在scheduler_tick中周期性调度通过调用curr进程所属调度sched_class的task_tick函数完成周期性调度的工作 而entity_tick中则通过check_preempt_tick...这个是调度最初向进程欠下的债务....关于place_entity函数, 我们之前在讲解CFS队列操作的时候已经讲的很详细了 参见linux进程管理与调度之CFS入队出队操作 设想一下子如果休眠进程的vruntime保持不变,

2.5K31

调度及CFS调度

调度的目的:最大限度的使用CPU时间。 Linux内核中用来安排调度进程执行的模块称为调度(Scheduler),它可以切换进程状态(执行、睡眠、退出等)。.../ 空闲调度 这五种调度优先级从高到低依次为:停机调度,限期调度,实时调度,公平调度,空闲调度 停机调度stop_sched_class:...(MAX_RT_PRIO + NICE_WIDTH) #define DEFAULT_PRIO (MAX_RT_PRIO + NICE_WIDTH / 2) 调度策略 Linux内核提供一些调度策略供用户应用程序来选择调度...const struct sched_class *sched_class; // 表示该进程所属的调度 CFS:完全公平调度。...Linux采用红黑树保存调度实体,按照虚拟时间从小到大存储在红黑树中。 调度通过各个组件模块及一系列数据结构,来排序和管理系统中的进程。

99040

linux 系统调度(四) -- 利用 chrt 命令查询与修改进程调度

引言 上一篇文章中,我们介绍了 linux 调度的演进: linux 进程调度(下) -- 调度演进 在上一篇文章中,我们知道,到 Linux 2.6.23 版本后,linux 实际上维护了一组调度来实现不同的调度需要...,它们被分为了四层: DL 调度:采用 sched_deadline 策略; RT 调度:采用 sched_rr 和 sched_fifo 策略; CFS 调度:采用 sched_normal 和...那么,我们怎么才能让我们的进程被不同层的调度调度呢?那就需要使用 linux 提供的十分有用的工具 -- chrt 来实现了,本文我们就来介绍一下这个命令的使用。...2. chrt 命令的介绍 chrt 命令是 linux 提供的一个底层应用指令,它可以在运行时设置进程的某些属性,还可以更改调度策略和调度优先级。...SCHED_FIFO 和 SCHED_RR 两个调度可以让我们去指定,因为 RT 调度是采用传统的 O(1) 调度算法来实现的基于时间片调度的策略的。

3.4K30
领券