Linux内核初探 之 进程(三) —— 进程调度算法
一、基本概念
- 抢占
- Linux提供抢占式多任务,基于时间片和优先级对进程进行强制挂起
- 非抢占的系统需要进程自己让步(yielding)
- 进程类型
- IO消耗型
- 经常处于可运行态,等待IO操作过程会阻塞
- 提高调度频率,缩短运行时间
- CPU消耗型
- cpu时间用于计算
- 降低调度频率,延长运行时间
- Linux优先保证响应性能,倾向于优化IO消耗型
- IO消耗型
进程优先级
内核的优先级
静态优先级:
static_prio = MAX_RT_PRIO + nice + 20 [100, 139]
实时优先级 —— 值越大优先级越高
rt_prio = 99(High) ~ 0(Low)
动态优先级 —— 值越小优先级越高
rt
prio = MAX_RT_PRIO - 1 - rt_prio [0, 99] 用于实时进程
普通
prio = static_prio [100, 139] 用于普通进程
normal优先级
normal_prio = MAX_PRIO - 20 [120] 默认进程优先级,nice = 0
常量
MAX_RT_PRIO = 100
MAX_PRIO = 140
nice = [-20, 19]
关系图
(High) 0 1 ... 98 99 100 101 ... 120 ... 138 139 (Low)
|__|_____________|___|___|___|____________|______________|___|
(High) 99 98 ... 1 0 100 101 ... 120 ... 138 139 (Low)
|__|_____________|___| |___|____________|______________|___|
rt_prio static_prio
-20 -19 ... 0 ... 18 19
|___|____________|______________|___|
nice
120
|
normal_prio
RT RT ... RT RT 0 1 ... 20 ... 38 39 (Low)
大专栏 Linux内核初探 之 进程(三) —— 进程调度算法top(PR) |__|_____________|___|___|___|____________|______________|___|
- 时间片
- IO消耗型需要短时间片提高系统响应,CPU需要长时间片减小切换消耗以及提高cache命中
- Linux默认时间片较短,且不是直接分配到进程,CFS分配处理器使用比,当新任务的使用比小于当前进程的时候,可以抢占当前任务
- 比如响应界面输入的处理器时间小于执行复杂计算,则前者可以抢占后者,使用户输入迅速得到响应
- nice值作为权重调整处理器使用比
二、Linux调度算法
- 调度器类schedular class
- schedular class以模块方式提供调度器,可动态添加,按优先级选取
- 完全公平调度CFS
- Linux默认
SCHED_OTHER策略
- Linux默认
- 按优先级分配时间片的问题
- 将nice值映射到绝对时间片,nice值差异越大,时间片差异越大。没有按照整个可用时间片的比例分配,导致优先级低的时候,时间片少,进程切换频繁
- 如nice值-20时间片100ms,20时间片5ms,则即使系统只有两个时间片20的进程,也各只有5ms
- 往往低优先级(高nice值)需要更长时间片,与策略相反
- 相对nice值的差异
- nice值1代表5ms处理器时间
- 为0和1,时间片为100和95,为19和20,时间片为10和5
- nice值加减1的效果取决于初始值
- nice值1代表5ms处理器时间
- 系统定时器决定了
- 时间片必需是定时器节拍的整数倍
- 两个时间片之间的差异
- 时间片会随定时器节拍改变
- 将nice值映射到绝对时间片,nice值差异越大,时间片差异越大。没有按照整个可用时间片的比例分配,导致优先级低的时候,时间片少,进程切换频繁
- 完全公平调度CFS
- 基于概念:将处理器时间平均分配给系统中的所有进程,每个进程的运行时间相当,运行时100%占有处理器
- 允许每个进程运行一段时间,选择运行最少的运行
- 按处理器使用比,nice值作为权重
- 小的调度周期交互性更好,但切换代价高,影响系统吞吐,被限制为1ms以避免切换消耗
- 进程所获得的处理器时间为其它可运行进程nice值的相对差
Linux内核初探 之 进程(三) —— 进程调度算法的更多相关文章
- 《Linux内核分析》 第八节 进程的切换和一般的执行过程
张嘉琪 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 Linux内核分析 第八 ...
- Linux内核设计第六周 ——进程的描述和创建
Linux内核设计第六周 ——进程的描述和创建 第一部分 知识点总结 一.进程描述符task_struct数据结构 1.操作系统的三大功能: 进程管理.内存管理.文件系统 2.进程的作用: 将信号.进 ...
- Linux内核分析(四)----进程管理|网络子系统|虚拟文件系统|驱动简介
原文:Linux内核分析(四)----进程管理|网络子系统|虚拟文件系统|驱动简介 Linux内核分析(四) 两天没有更新了,上次博文我们分析了linux的内存管理子系统,本来我不想对接下来的进程管理 ...
- Linux内核分析第八周——进程的切换和系统的一般执行过程
Linux内核分析第八周--进程的切换和系统的一般执行过程 李雪琦+原创作品转载请注明出处 + <Linux内核分析>MOOC课程http://mooc.study.163.com/cou ...
- Linux内核设计第八周 ——进程的切换和系统的一般执行过程
Linux内核设计第八周 ——进程的切换和系统的一般执行过程 第一部分 知识点总结 第二部分 实验部分 1.配置实验环境,确保menu内核可以正常启动 2.进入gdb调试,在shedule和conte ...
- 《Linux内核分析》第三周学习报告
<Linux内核分析>第三周学习报告 ——构造一个简单的Linux系统MenuOS 姓名:王玮怡 学号:201351 ...
- 《Linux内核分析》第三周学习笔记
<Linux内核分析>第三周学习笔记 构造一个简单的Linux系统MenuOS 郭垚 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.stud ...
- Linux内核中影响tcp三次握手的一些协议配置
在Linux的发行版本中,都存在一个/proc/目录,有的也称它为Proc文件系统.在 /proc 虚拟文件系统中存在一些可调节的内核参数.这个文件系统中的每个文件都表示一个或多个参数,它们可以通过 ...
- 【读书笔记】《Linux内核设计与实现》进程管理与进程调度
大学跟老师做嵌入式项目,写过I2C的设备驱动,但对Linux内核的了解也仅限于此.Android系统许多导致root的漏洞都是内核中的,研究起来很有趣,但看相关的分析文章总感觉隔着一层窗户纸,不能完全 ...
随机推荐
- 《Premiere Pro 2020》初心版_v3 14.0.1.71
<Premiere Pro 2020>初心版_v3 下载地址(78e7) SHA1:8B081196C1756CE9477A0D056D6331907B3DDFDC 版本信息 发行版 ...
- LeetCode——853.车队
N 辆车沿着一条车道驶向位于 target 英里之外的共同目的地. 每辆车 i 以恒定的速度 speed[i] (英里/小时),从初始位置 position[i] (英里) 沿车道驶向目的地. 一辆车 ...
- kaggle注册获取数据
安装谷歌访问助手,主要参考下面的作者写的 https://segmentfault.com/a/1190000020548973?utm_source=tag-newest 安装之后,打开蓝灯或其他翻 ...
- tomcat更新class不生效
替换线上lib里的class不生效,需要想想是不是前人为了图方便在classes里面扔了一份老版本class
- Linux基础篇八:VIM
新知识: 普通模式光标跳转: G ##光标跳转到末端 (shift +g) gg ##光标跳转到开端 Ngg 15gg ##光标跳转到当前文本中的15行 $ ##光标移动到当前 ...
- LeetCode No.121,122,123
No.121 MaxProfit 买卖股票的最佳时机 题目 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 如果你最多只允许完成一笔交易(即买入和卖出一支股票),设计一个算法来计算你 ...
- python调用存储过程失败返回1787错误
(1787, 'When @@GLOBAL.ENFORCE_GTID_CONSISTENCY = 1, the statements CREATE TEMPORARY TABLE and DROP T ...
- 简单的文件上传服务器(上传到FastDFS服务器)
现在文件服务器使用越来越多,其中FastDFS文件服务器非常出色,可以支持分布式存储,多文件系统集群和多主机备份 环境中使用的文件服务器为172.16.100.10,其中trackerd服务和stor ...
- js原型理解
https://www.cnblogs.com/liuhw/p/10646717.html __proto__的默认指向:https://www.jianshu.com/p/686b61c4a43d
- telnet不是内部或外部命令的问题解决
在windows DOS 命令窗口中输入telnet命令,出现如下提示信息: 可能是没有安装telnet客户端的原因,又得开始捣鼓了 www.2cto.com 依次点击"开 ...