进程优先级与进程调度

简介: 进程优先级与进程调度

进程优先级

进程优先级:进程要访问某种资源,每个进程享受资源的先后顺序,那么为什么进程要有优先级呢?在计算机中的CPU资源过少,而进程过多,每个进程都需要通过优先级和排队,进而形成一个公平、有序的环境。

在Linux中,有进程有进程优先级(PRI),PRI 是一个数字,范围在 [60,99) 之间,数字越小表示进程的优先级越高!Linux 中默认一个普通进程的优先级是80,并且进程的优先级可以被修改:只能改变进程的 nice 值,而不是直接改变进程的 PRI 进行优先级的调整。

那为什么进程优先级的范围只是在 [60,99) 之间呢?

如果进程优先级范围不加限制,有些人就会将自己进程的优先级调整的特别高,别人进程的优先级调整的特别低;优先级较高的进程会优先得到资源,而后面又会有源源不断的进程产生,这就导致常规进程很难享受到CPU的资源!进而导致进程饥饿问题。

进程的调度与切换

在操作系统中,进程都是基于时间片排队进行轮转执行的,而不是将进程放在CPU上直接将所有的代码一次性跑完!

进程加载到CPU上,在运行的时候,会产生大量的临时数据,放在CPU的寄存器中,这些放在CPU寄存器中所有的临时数据,叫做进程的硬件上下文

硬件上下问是干什么的?为什么要储存在寄存器里?硬件上下问是为了让我们的进程得以保存数据,所以也叫保护上下文。

进程在运行的时候,在CPU上储存有临时数据,这些数据存储在CPU的特定寄存器中,当进程在一个时间片内没有运行结束的时候,进程就会将这些数据从寄存器中取出,保存在自己的内部(保存是为了后面更好的恢复),等到CPU再次调度此进程的时候,CPU就可以在进程中取出这些数据,通过这些数据就能进行硬件上下文的恢复(即确定应该从哪里开始继续完成进程的执行)

CPU存储这些数据的寄存器只有一套,每次进程来都会更新CPU中的特定寄存器,等到没执行完的进程再次被调度的时候,又从进程自身取出数据恢复到CPU特定寄存器中继续开始进程的执行。

基于Linux 2.6 内核的进程调度队列与调度原理

从上文已经可以知道,进程是基于时间片在队列中进行轮转调度的,并且进程是有优先级的,优先级高的进程优先被调度,那么如何做到相对公平呢?后启动的优先级高的进程会比先启动的优先级较低的进程率先被CPU运行?

其实,在CPU中是有两个进程调度队列的的数组的,每个数组中都包含有40个优先级不同的队列,每个队列中都是优先级相同的进程在排队。

设想下面的场景:当前有4个进程在第一个调度队列数组中,两个进程在优先级为60的队列中,两个进程在优先级为80的进程中,这些进程在CPU中基于时间片进行轮转执行。那么,这些队列运行未结束的时候启动的队列,将会被链接在另一个调度队列的数组中,优先级相同的进程按照优先顺序在一个队列中。

当第一个队列中的进程结束后,只需要将指向这个调度队列的指针与指向另一个调度队列的指针交换指向,即可让一下一个队列的进程开始运行,而之后开启的进程,就都按先后顺序和进程优先级链接在这个调度队列中,待另一个队列运行结束后,再次交换指针指向即可。

那么,对于一个调度队列的本身,里面时如何做到进程公平调度的?

已知优先级相同的进程链接在一个队列中,优先级高的队列先运行,那么结果就显而易见了:优先级高的进程排成队列,基于时间片进行轮转执行各个进程;当高优先级的进程运行结束后,再基于时间片对较低优先级的进程队列基于时间片进程轮转执行调度。当所有优先级的调度队列全部都运行结束后,切换至等待队列数组。这样不会让普通且进优先级高的进程贸然插队,也不会让进程优先级低的队列等不到运行的机会而导致进程饥饿,做到了相对的公平。

相关文章
|
2月前
|
算法 调度 UED
深入理解操作系统:进程调度与优先级队列
【10月更文挑战第31天】在计算机科学的广阔天地中,操作系统扮演着枢纽的角色,它不仅管理着硬件资源,还为应用程序提供了运行的环境。本文将深入浅出地探讨操作系统的核心概念之一——进程调度,以及如何通过优先级队列来优化资源分配。我们将从基础理论出发,逐步过渡到实际应用,最终以代码示例巩固知识点,旨在为读者揭开操作系统高效管理的神秘面纱。
|
1月前
|
存储 算法 调度
深入理解操作系统:进程调度的奥秘
在数字世界的心脏跳动着的是操作系统,它如同一个无形的指挥官,协调着每一个程序和进程。本文将揭开操作系统中进程调度的神秘面纱,带你领略时间片轮转、优先级调度等策略背后的智慧。从理论到实践,我们将一起探索如何通过代码示例来模拟简单的进程调度,从而更深刻地理解这一核心机制。准备好跟随我的步伐,一起走进操作系统的世界吧!
|
11天前
|
Java Linux API
[JavaEE]———进程、进程的数据结构、进程的调度
操作系统,进程任务,PCB,PID,内存指针,文件描述符表,进程的调度,并发编程,状态,优先级,记账信息,上下文
|
2月前
|
消息中间件 算法 调度
深入理解操作系统:进程管理与调度
操作系统是计算机系统的核心,负责管理和控制硬件资源、提供用户接口以及执行程序。其中,进程管理是操作系统的重要组成部分,它涉及到进程的创建、调度、同步和通信等方面。本文将深入探讨进程管理的基本概念、进程调度算法以及进程间的同步和通信机制。通过本文的学习,读者将能够更好地理解操作系统的工作原理,并掌握进程管理的基本技能。
55 11
|
2月前
|
算法 调度 UED
深入理解操作系统:进程管理与调度策略
操作系统作为计算机系统的核心,其进程管理和调度策略对于系统性能和用户体验至关重要。本文将通过直观的代码示例和浅显易懂的语言,带领读者了解操作系统如何有效管理进程以及常见的进程调度算法。我们将从进程的基本概念出发,逐步深入到进程状态、进程控制块(PCB)的作用,最后探讨不同的调度算法及其对系统性能的影响。无论您是初学者还是有一定基础的开发者,都能从中获得有价值的信息。
|
2月前
|
负载均衡 算法 调度
深入理解操作系统:进程管理与调度
在数字世界的心脏,操作系统扮演着至关重要的角色。它如同一位精明的指挥家,协调着硬件资源和软件需求之间的和谐乐章。本文将带你走进操作系统的核心,探索进程管理的艺术和调度策略的智慧。你将了解到进程是如何创建、执行和消亡的,以及操作系统如何巧妙地决定哪个进程应该在何时获得CPU的青睐。让我们一起揭开操作系统神秘的面纱,发现那些隐藏在日常计算背后的精妙机制。
|
2月前
|
调度 开发者
深入理解操作系统之进程调度
在计算机科学领域,操作系统是核心的一环,它管理着计算机硬件资源,并提供接口供上层软件运行。本文将通过深入浅出的方式,探讨操作系统中至关重要的一个概念——进程调度。我们将从基础理论出发,逐步展开讲解进程调度的原理和实现,并配以实际代码示例,旨在帮助读者更好地理解和掌握这一主题。文章不仅适合初学者建立基础,也适合有一定基础的开发者深化理解。
|
2月前
|
算法 调度 UED
深入理解操作系统:进程管理与调度策略
【10月更文挑战第40天】在数字世界中,操作系统是连接硬件与软件的桥梁,它管理着计算机资源和提供用户服务。本文将深入探讨操作系统中的进程管理与调度策略,揭示它们如何协调多任务运行,保证系统高效稳定运作。通过代码示例,我们将展示进程创建、执行以及调度算法的实际应用,帮助读者构建对操作系统核心机制的清晰认识。
|
2月前
|
算法 调度 UED
深入理解操作系统:进程管理与调度策略
【10月更文挑战第34天】本文旨在探讨操作系统中至关重要的一环——进程管理及其调度策略。我们将从基础概念入手,逐步揭示进程的生命周期、状态转换以及调度算法的核心原理。文章将通过浅显易懂的语言和具体实例,引导读者理解操作系统如何高效地管理和调度进程,保证系统资源的合理分配和利用。无论你是初学者还是有一定经验的开发者,这篇文章都能为你提供新的视角和深入的理解。
46 3
|
2月前
|
算法 Linux 调度
深入理解操作系统之进程调度
【10月更文挑战第31天】在操作系统的心脏跳动中,进程调度扮演着关键角色。本文将深入浅出地探讨进程调度的机制和策略,通过比喻和实例让读者轻松理解这一复杂主题。我们将一起探索不同类型的调度算法,并了解它们如何影响系统性能和用户体验。无论你是初学者还是资深开发者,这篇文章都将为你打开一扇理解操作系统深层工作机制的大门。
45 0