【进程调度】Linux内核的进程调度队列--runqueue

简介: 【进程调度】Linux内核的进程调度队列--runqueue

前言

在了解进程的基本概念后,我们已经清楚一个进程到底是什么了,那么一个进程又是如何被调度的呢?这个过程发生了神呢

runqueuer

runqueue运行队列是Linux系统内核中非常重要的一个组成部分。它是用于管理所有的进程和线程的队列,使它们能够按照特定的优先级被调度执行。

上图是Linux2.6内核中进程队列的数据结构

其中runqueue维护了一个活动队列,和一个过期队列。

活动队列


活动队列维护了正在运行时间片还没有结束的进程,按照优先级放在该队列。

nr_activeb表示总共有多少个运行状态的进程

queue[140]:其中每一个元素都是一个task_struct指针,指向一个队列的首元素。每一个队列都表示一个优先级,queue下标表示的就是优先级。比如一个正在运行的进程的优先级为1,那么这个进程就在队列queue[1]中。

当我们需要在这个queue[]队列数组中找一个进程被CPU执行时。操作系统会在这个数组中从头开始,也就是从优先级最高的队列开始,找到第一个非空的队列。再在这个队列中运行第一个进程,于是这样就完成了一次进程调度。

那系统是如何找到这个“第一个非空进程队列”的呢?

于是我们就可以借用long bitmap[5]这个数组了。

把bitmap当成一个01序列的位图,一共有32*5=160个比特位。第n位比特位为1,表示queue第n个元素指向的队列非空。

于是,我们可以遍历整个bitmap数组,如果bitmap[0]为0,则意味着前32个比特位都是0,也意味着queue前32个元素都是空。直到遇到bitmap[i]>0,再去遍历这个bitmap[i]的二进制位,遇到1就结束。

相比于遍历queue去找到第一个非空进程队列,这样用位图的方式,遍历一次就能筛选32个比特位,也就是32个为空的队列,无疑大大提升了效率。

过期队列

过期队列和活动队列结构一模一样 ,只不过过期队列上的queue里的指针指向的是时间片耗尽的进程。当活动队列上的进程时间片耗尽了就会调出到过期队列。

值得注意的是,当活动队列的所有进程都被处理完的时候,会重新分配给过期队列中的进程时间片。

active指针和expired指针

在runqueue里,active指针永远指向活动队列,相反,expired指针永远指向过期队列。

由于活动队列中的进程只出不进,越来越少。过期队列中的进程,只进不出,越来越多。

当活动队列中的进程都被调度完了之后,一部分进程已经完全运行结束,一部分进程则是回到过期队列等待下次被调度。此时交换active指针和expired指针的内容,原来的过期队列被赋予“生命”成为新的活动队列,继续被调度。原来的活动队列则成为过期队列,接收那些还想被调度但是没有CPU时间片的进程,并等待下一次成为活动队列。

总结:

至此我们清楚了系统是如何查找一个合适的进程被CPU调度的,这种调度算法的时间复杂度是O(1)的,不随着进程的增多而导致时间成本的增加,我们将其称之为进程调度O(1)算法

相关文章
|
1天前
|
存储 Linux Shell
Linux进程概念(上)
冯·诺依曼体系结构概述,包括存储程序概念,程序控制及五大组件(运算器、控制器、存储器、输入设备、输出设备)。程序和数据混合存储,通过内存执行指令。现代计算机以此为基础,但面临速度瓶颈问题,如缓存层次结构解决内存访问速度问题。操作系统作为核心管理软件,负责资源分配,包括进程、内存、文件和驱动管理。进程是程序执行实例,拥有进程控制块(PCB),如Linux中的task_struct。创建和管理进程涉及系统调用,如fork()用于创建新进程。
13 3
Linux进程概念(上)
|
2天前
|
缓存 监控 安全
Linux top命令详解:持续监听进程运行状态
Linux top命令详解:持续监听进程运行状态
14 3
|
3天前
|
存储 负载均衡 算法
深入理解操作系统的进程调度
【6月更文挑战第20天】本文将探讨操作系统中的进程调度,包括其定义、重要性以及常见的调度算法。我们将通过具体的例子和代码片段来深入理解进程调度的工作原理和实现方式。最后,我们将讨论进程调度在现代操作系统中的应用和挑战。
|
5天前
|
Linux
查看linux内核版本
在Linux中查看内核版本可使用`uname -r`、`cat /proc/version`、`lsb_release -a`(若安装LSB)、`/etc/*release`或`/etc/*version`文件、`dmesg | grep Linux`、`cat /sys/class/dmi/id/product_name`、`hostnamectl`、`kernrelease`(如果支持)、`rpm -q kernel`(RPM系统)和`dpkg -l linux-image-*`(Debian系统)。
15 4
|
6天前
|
安全 Linux 数据处理
探索Linux的kmod命令:管理内核模块的利器
`kmod`是Linux下管理内核模块的工具,用于加载、卸载和管理模块及其依赖。使用`kmod load`来加载模块,`kmod remove`卸载模块,`kmod list`查看已加载模块,`kmod alias`显示模块别名。注意需有root权限,且要考虑依赖关系和版本兼容性。最佳实践包括备份、查阅文档和使用额外的管理工具。
|
5天前
|
调度
操作系统之进程调度机制
操作系统之进程调度机制
9 1
|
6天前
|
Linux 数据处理
深入了解Linux命令kill:终止进程的艺术
**Linux的`kill`命令详解:高效管理进程的工具** `kill`命令在Linux中用于向进程发送信号,如SIGTERM(默认)和SIGKILL,以终止或影响进程行为。它通过进程ID(PID)操作,支持多种信号和选项,如`-l`列出信号,`-9`强制杀进程。例如,`kill 1234`发送TERM信号,`kill -9 1234`发送KILL信号。使用时注意,SIGKILL是不可忽视的,可能导致数据丢失。配合`pgrep`和`pkill`能更灵活管理进程。了解进程依赖和使用其他命令如`ps`和`top`可优化系统资源管理。
|
6天前
|
负载均衡 算法 调度
深入理解操作系统之进程调度
本文旨在探究操作系统核心机制之一——进程调度。文章首先概述进程与线程的基本概念,随后详细解析进程调度的目标、常见算法及其优缺点,并探讨现代操作系统中进程调度的高级话题,如多核调度和实时系统的调度策略。通过实例分析,本篇文章将帮助读者深化对进程调度复杂性的理解,并指出未来可能的发展方向。
|
10天前
|
Linux Shell 编译器
Linux进程——Linux环境变量
Linux进程——Linux环境变量
11 3
|
10天前
|
Linux Shell C语言
Linux进程控制——Linux进程程序替换
Linux进程控制——Linux进程程序替换
15 2