【Linux系统化学习】进程优先级 | 进程饥饿 | 进程切换

简介: 【Linux系统化学习】进程优先级 | 进程饥饿 | 进程切换

进程优先级

什么是优先级

系统按照不同的优先级调度进程的运行,得到CPU资源的先后顺序。

为什么会有优先级?

因为CPU的资源有限,需要调度的进程却很多。

如何做到的?

我们知道内存中的每一个进程都有一个PCB,这个PCB中有一个整数字段;数字越小,优先级越大;反之。

总结:

·       排队的本质就是确认优先级

·       cpu资源分配的先后顺序,就是指进程的优先权(priority)。

·       优先权高的进程有优先执行权利。配置进程优先权对多任务环境的linux很有用,可以改善系统性能。

·       还可以把进程运行到指定的CPU上,这样一来,把不重要的进程安排到某个CPU,可以大大改善系统整体性能。


优先级的动态调整

Linux下的优先级是支持用户手动调整的,我么先使用指令认识下几个名词。

·       指令:ps -l

 

0a0f6e5fff274b58aa55832a9b768032.png

我们很容易注意到其中的几个重要信息,有下:

·       UID : 代表执行者的身份

·       PID : 代表这个进程的代号

·       PPID :代表这个进程是由哪个进程发展衍生而来的,亦即父进程的代号

·       PRI :代表这个进程可被执行的优先级,其值越小越早被执行

·       NI :代表这个进程的nice值

查看进程优先级的命令

·       top

·       进入top后按“r”–>输入进程PID–>输入nice值

PRI 和 NI

·       PRI也还是比较好理解的,即进程的优先级,或者通俗点说就是程序被CPU执行的先后顺序,此值越小进程的优先级别越高

·       那NI呢?就是我们所要说的nice值了,其表示进程可被执行的优先级的修正数值

·       PRI值越小越快被执行,那么加入nice值后,将会使得PRI变为:PRI(new)=PRI(old)+nice

·       这样,当nice值为负值的时候,那么该程序将会优先级值将变小,即其优先级会变高,则其越快被执行

·       所以,调整进程优先级,在Linux下,就是调整进程nice值

·       nice其取值范围是-20至19,一共40个级别。 (使较为均衡的让每一进程得到调度

·       NI值最小是-20 ,超过一律按-20处理;最大为19,超过一律按19处理;

PRI VS NI

·       需要强调一点的是,进程的nice值不是进程的优先级,他们不是一个概念,但是进程nice值会影响到进程的优先级变化。

·       可以理解nice值是进程优先级的修正修正数据

修改进程优先级

用户是不可以直接修改PRI的只可以通过修改中间变量NI的值来间接修改PRI

新的PRI=旧的PRI+NI

旧的PRI是固定的数80,只需要NI的变化来调整即可

提高优先级

 dbc4c52405554c809159c175bc6cbc66.png

fc2ba423bea5493a82b3b85ca60bee64.png

降低优先级

a2957a6e78864a80bef59f0090483819.png

db41e5185daf447f9c911bac984b34bb.png

饥饿进程

上面说到PRI的值是通过中间值NI来间接调节的;如果NI没有一个取值范围,那么用户随意通过NI来修改PRI,私自将一些进程的PRI修改的很小,优先级很大,导致这些优先级大的进程一直使用CPU资源,而导致一些进程享受不到CPU资源,这就是饥饿进程


进程切换

·       进程被CPU调度时并不是一直占据CPU运行,而是每隔一段时间(时间片)从CPU上剥离下来。

·       Linux内核支持进程之间进程CPU资源抢占,是基于时间片的轮转式抢占内核。

以我们编写的C语言代码为例:

代码中多多少少基本都需要一些运算,这些运算就需要调度到CPU中处理,当代码量非常大的时候一个时间片肯定不够CPU处理这些代码的,程序没运行完就会被切换另一个进程。那运行到一半的代码,下次轮到它调度时候则么办呢?又例如在自定义函数中创建的变量出栈是如何返回给外部的呢?

寄存器和PCB联合配合进程切换

其实在我们的CPU中含有很多的寄存器,包括:eax、ebx、ecx、edx、ss、cs、ds、gs、fs

、edp、esp、eip、status等等;这些寄存器充当代码的临时空间

自定义函数入栈开辟空间,出栈销毁空间。出栈时将我们需要返回的变量的值存储在寄存器中(eax),在主函数使用时拿出来。

当需要进程切换时寄存器保存着我们产生的各种临时数据(包括当前代码的运行行数eip程序计数器),也就是我们的进程的硬件上下文;寄存器将我们这些临时数据打包交给我们的PCB;寄存器也不许用清理这些数据,等到进程切换时PCB又把上次运行的数据交给寄存器即可;这样就实现了我们进程的切换。

总结:

·       竞争性: 系统进程数目众多,而CPU资源只有少量,甚至1个,所以进程之间是具有竞争属性的。为了高效完成任务,更合理竞争相关资源,便具有了优先级

·       独立性: 多进程运行,需要独享各种资源,多进程运行期间互不干扰

·       并行: 多个进程在多个CPU下分别,同时进行运行,这称之为并行

·       并发: 多个进程在一个CPU下采用进程切换的方式,在一段时间之内,让多个进程都得以推进,称之为并发

 

 

相关文章
|
6月前
|
监控 关系型数据库 MySQL
在CentOS系统中,如何统计哪个进程打开了文件描述符?
利用上述方法,你可以有效地监控和统计CentOS系统中的进程打开的文件描述符数量,以帮助排查错误或优化系统配置。通过组合使用各种工具和命令,可以获得对系统状态和行为的深入了解,进而做出相应的调整和
306 5
|
算法 调度 UED
深入理解操作系统:进程调度与优先级队列
【10月更文挑战第31天】在计算机科学的广阔天地中,操作系统扮演着枢纽的角色,它不仅管理着硬件资源,还为应用程序提供了运行的环境。本文将深入浅出地探讨操作系统的核心概念之一——进程调度,以及如何通过优先级队列来优化资源分配。我们将从基础理论出发,逐步过渡到实际应用,最终以代码示例巩固知识点,旨在为读者揭开操作系统高效管理的神秘面纱。
麒麟系统mate-indicators进程占用内存过高问题解决
【10月更文挑战第7天】麒麟系统mate-indicators进程占用内存过高问题解决
1725 2
|
弹性计算 运维 监控
基于进程热点分析与系统资源优化的智能运维实践
智能服务器管理平台提供直观的可视化界面,助力高效操作系统管理。核心功能包括运维监控、智能助手和扩展插件管理,支持系统健康监控、故障诊断等,确保集群稳定运行。首次使用需激活服务并安装管控组件。平台还提供进程热点追踪、性能观测与优化建议,帮助开发人员快速识别和解决性能瓶颈。定期分析和多维度监控可提前预警潜在问题,保障系统长期稳定运行。
563 17
如何在 Linux 系统中查看进程占用的内存?
如何在 Linux 系统中查看进程占用的内存?
2889 58
|
监控 搜索推荐 开发工具
2025年1月9日更新Windows操作系统个人使用-禁用掉一下一些不必要的服务-关闭占用资源的进程-禁用服务提升系统运行速度-让电脑不再卡顿-优雅草央千澈-长期更新
2025年1月9日更新Windows操作系统个人使用-禁用掉一下一些不必要的服务-关闭占用资源的进程-禁用服务提升系统运行速度-让电脑不再卡顿-优雅草央千澈-长期更新
2790 2
2025年1月9日更新Windows操作系统个人使用-禁用掉一下一些不必要的服务-关闭占用资源的进程-禁用服务提升系统运行速度-让电脑不再卡顿-优雅草央千澈-长期更新
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
703 13
|
网络协议 Linux 虚拟化
如何在 Linux 系统中查看进程的详细信息?
如何在 Linux 系统中查看进程的详细信息?
1616 1
|
7月前
|
Linux 应用服务中间件 Shell
二、Linux文本处理与文件操作核心命令
熟悉了Linux的基本“行走”后,就该拿起真正的“工具”干活了。用grep这个“放大镜”在文件里搜索内容,用find这个“探测器”在系统中寻找文件,再用tar把东西打包带走。最关键的是要学会使用管道符|,它像一条流水线,能把这些命令串联起来,让简单工具组合出强大的功能,比如 ps -ef | grep 'nginx' 就能快速找出nginx进程。
825 1
二、Linux文本处理与文件操作核心命令
|
7月前
|
Linux
linux命令—stat
`stat` 是 Linux 系统中用于查看文件或文件系统详细状态信息的命令。相比 `ls -l`,它提供更全面的信息,包括文件大小、权限、所有者、时间戳(最后访问、修改、状态变更时间)、inode 号、设备信息等。其常用选项包括 `-f` 查看文件系统状态、`-t` 以简洁格式输出、`-L` 跟踪符号链接,以及 `-c` 或 `--format` 自定义输出格式。通过这些选项,用户可以灵活获取所需信息,适用于系统调试、权限检查、磁盘管理等场景。
477 137
下一篇
开通oss服务