进程优先级

一、基本概念:是进程得到CPU资源的先后顺序。

本质是目标资源稀缺。

优先级:能得到资源,先后的问题。

权限:是否得到资源。

进程优先级是一个数字,值越低越高。

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

基于时间片的分时操作系统,要考虑公平性,进程的优先级差别就不会很大,否则导致资源分配不均。优先级未来可能变化但幅度不会很大。

二、查看系统进程:

1.在linux或者unix系统中,用ps‒l命令则会类似输出以下几个内容:

系统怎么知道一个进程的拥有者所属组和other?使用UID。

Linux系统中,访问任何资源都是进程访问,进程就代表用户。

PRI:进程的优先级,默认80

NI:进程优先级的修正数据,nice值。

进程的真实优先级=PRI+nice,默认都是从80开始调整

Linux进程优先级范围60,99,为了资源调度更公平。

2.进程与进程之间的关系:竞争、独立、并行、并发

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

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

并行:多个进程在多个CPU同时进行。

并发:多个进程在一个CPU切换进行同时推进。

3.进程切换:死循环进程如何进行?一个进程占有CPU代码会不会跑完?不会,时间片到了就会切换。

理解CPU和寄存器:寄存器就是CPU内的临时保存数据的空间。寄存器不等于寄存器里的数据。

如何切换:当兵:学校就叫CPU,辅导员叫做调度器,你是进程,学籍就是进程运行的临时数据,CPU寄存器内的临时数据,保留学籍,保留上下文数据,CPU寄存器内的数据保留起来,去当兵,就是进程被从CPU上剥离下来。回来了就相当于做了一次切换。

所以进程切换最核心的就是保存和恢复当前进程硬件上下文的数据即CPU寄存器的内容

当前进程的上下文数据保存在PCB里。

三、调度:

一个CPU一个运行队列runqueue,里面有queue140,是一个指针数组,有一百四十个数字,前面100个是实时优先级,后面40个才是优先级。里面保存到都是task_struct*类型的

优先级计算:x-60+(140-40),里面保存的都是tast struct*,优先级多少就链入到里面,宏观上先看优先级,优先级相同的就先进先出。FIFO。

调度器选择一个进程调度,找一个进程时间复杂度O(N),如何挑选进程?

通过位图,unsigned int bitmap5,比特位的位置表示queue140的下标,内容表示是否存在进程。比如00000100,调度器先挑队列,再挑进程,以后只需要看位图就可以调度进程,这样子可以做到以O(1)的时间复杂度去挑选进程。

设计一个结构体struct runqueue_elem,里面有array、bitmap位图、queue40存放优先级数字。

runqueue里面还有两个指针,类型是struct runqueue_elem*,一个叫active,一个叫expired,一个指向,一个指向, 然后这两个指针存放在struct runqueue_elem里的数组array里。

active指向的queue140调出要进行的进程到CPU完成之后就调回expired里的queue140,调度过的进程都要到过期队列里,调度的过程中活跃队列里进程会越来越少,过期队列里会越来越多。这是为了已经调度过的队列不要再插优先级低且还没调度过的队列里。直到活跃队列里没有进程了,就交换active和expired的地址然后以此类推。

相关推荐
zylyehuo8 小时前
Linux 彻底且安全地删除文件
linux
用户8055336980321 小时前
主线 U-Boot 上 RK3506:和闭源 rkbin 拔河的三个隐性契约
linux·嵌入式
用户0340952979121 小时前
linux fcitx 5 雾凇拼音 设置在中文输入法下仍然输入英文标点
linux
Web3探索者3 天前
可视化服务器管理和传统命令行区别是什么?新手教程:Linux 运维到底该用图形界面还是 SSH 命令行?
linux·ssh
zylyehuo3 天前
Linux系统中网线与USB网络共享冲突
linux
Sokach10154 天前
Linux Shell 脚本从零到能用:一个新手的一天学习总结
linux
AlfredZhao5 天前
Docker 容器时区不对,`timedatectl` 不存在怎么办?
linux·timezone
zzzzzz3106 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
XIAOHEZIcode6 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
A小辣椒8 天前
TShark:Wireshark CLI 功能
linux