Linux 进程优先级

什么是进程的优先级

优先级:对资源的访问顺序!注意优先级与权限的区别,优先级决定的是访问资源的顺序,这意味着无论是谁都可以访问到资源;但是如果你没有权限,你是不能访问资源的!
这个应该比较好理解,我们可以通过生活中的例子来理解:

  • 食堂排队打饭,排队的过程不就是确定优先级的过程嘛!虽然吃到饭的顺序因优先级有区别,但是所有的同学都可以吃到饭嘛!
  • 小时候,班主任可能会根据同学成绩的高低来决定位置选择的顺序!虽然位置选择的顺序因为优先级有差异,但是每个同学都能得到自己的位置!

为什么要有进程的优先级

因为 CPU 资源是有限的,而进程数量远大于 CPU 数量,这就注定了进程之间是竞争关系。
想象一下,食堂中的同学们也是竞争关系,食堂打饭如果不排队,那些女生和比较弱小的男生可能就吃不到饭了!
同理,操作系统必须保证所有进程进行良性竞争,因此,就必须确定进程之间的优先级!
如果一个进程长时间得不到 CPU 资源,该进程代码长时间得不到推进,这就是进程的饥饿问题

查看进程优先级

ps -l # 显示当前终端下用户启动的进程
ps -al # 显示当前用户启动的所有进程

在这里插入图片描述

  • UID:linux 管理用户也是用数字来管理的,并不是通过用户名来管理的!
    在这里插入图片描述
    我们可以通过一个命令来查看用户名对应的 UID,如上图。

    id 用户名
    

    我们可以看到 ls -alls -aln 的差别就是将文件的所属用户和所属用户组分别变成了 uidgroups 也就是数字版本!

  • PRINIPRI 表示的就是进程的优先级。NI:是 niceness 的缩写,修改进程的优先级就是修改这个 niceness 值!其中,PRI 的值越低表示进程的优先级越高
    修改进程优先级有一个公式:
    P R I ( n e w ) = P R I ( o l d ) + N I PRI(new) = PRI(old) + NI PRI(new)=PRI(old)+NI

修改进程优先级

top

top 命令不仅可以用来查看进程,也可以用来修改进程的 nice 值!
步骤:
1. 输入 top,然后回车。
2. 输入 r
3. 输入进程的 pid,然后回车。
4. 输入 nice 值,回车。

上面的四部之后就完成修改进程的优先级了!注意:top 命令只有管理员身份才能修改进程优先级
在这里插入图片描述
我通过 top 命令将 NI 修改成了:-10。于是进程的优先级 PRI 就变成了: 80 + ( − 10 ) = 70 80 + (-10) = 70 80+(10)=70


既然我能够修改优先级了,我是不是就可以将我自己写的进程的优先级改的很高很高,使得我的进程几乎一直在被调度?
事实上,Linux 不想过多的让用户参与进程优先级的调整,在我们手动修改进程的优先级时,NI 是有取值范围的:
N I ∈   [ − 20 , 19 ] NI \in \space [-20, 19] NI [20,19]
这就意味着,PRI 也是有范围的:
P R I ∈   [ 60 , 99 ] PRI \in \space [60, 99] PRI [60,99]
当我们修改 NI 值超过他的范围时就会按照他的上限或者下限取值!
注意:当我们第二次修改进程的优先级时,刚才讲到的公式中的 PRI(old) 依旧还是 80!事实上这个公式可以这么写:
P R I ( n e w ) = 80   +   N I PRI(new) = 80 \space + \space NI PRI(new)=80 + NI

nicerenice 这两个命令也可以修改进程的优先级,因为修改进程的优先级本身就不是特别好,这里就不再讲解了!您可以自行百度!

操系统如何根据进程的优先级展开调度

位图,想必现在你已经十分熟悉了吧!如你需要复习复习,请点击➡️C++实现位图

我们知道,处于 R 状态的进程都待在运行队列中!Linux 内核 2.6 版本中的运行队列维护了以下字段(当然内核源码可能与这里讲的有差距,但都是差不多一个意思):

strcut run_queue
{
	bitmap isEmpty; //这是一个位图结构体 bitmap 定义的变量
	task_struct** run; //指向运行队列的指针
	task_struct** wait; //指向运行队列的镜像队列的指针
	task_struct* running[140]; //运行队列
	task_stuct* waiting[140]; //运行队列的镜像队列
};
  • running 是一个指针数组,其中的每一个元素都指向同一个进程优先级链接而成的进程队列的头结点!那么为啥数组的大小是 140 呢?其中 [0 , 99] 是给写特殊进程使用的,这里我们用不到哈![100, 139] 之间恰好有 40 个数字,正好对应 [60, 99] 这 40 个优先级!
    在这里插入图片描述
    running 数组大概就是上图的样子!

  • run:这是一个二级指针,一开始的时候,run 指针指向的就是 running 数组,CPU 将通过 run 指针找到 running 数组,从中选择优先级最高的进程执行。例如:当 PRI = 60 的进程执行一次之后,就会执行 running 数组中下标为 101 的进程队列中的进程!依次类推!

  • waiting 也是一个指针数组,他的结构和 running 数组完全一样,当 running 数组中一个进程的时间片消耗完毕,并且这个进程还处于 R 状态,就会将这个进程放入 waiting 数组中相应的位置!
    比如:running 数组中下标为 100 的位置代表进程优先级为 60 的进程队列,当这个队列中的一个进程时间片消耗完,并且他还可以继续放在 CPU 上运行(依然处于 R 状态),那么他就会放入 waiting 数组中下标为 100 的位置,等待下一次被执行!
    当我们新创建了一个进程,他要在 CPU 上运行,也得先在 waiting 数组中属于该进程的优先级的那个队列中放着!

  • waitrun 一样都是二级指针,wait 一开始指向的就是 waiting 数组!

  • isEmpty 这是一个位图结构,bitmap 的定义就是下面这样的:

    struct bitmap
    {
    	char bits[5];
    };
    

    bitmapbits 数组正好是 40 个比特位,对应每一个优先级的队列!
    如果 running 数组中某一个优先级队列中的每个进程的时间片全部都消耗完毕,那么在 bits 数组中的对应比特位就会被置位 0。例如:running 数组中下标为 100 的位置对应的进程队列中的所有进程的时间片消耗完毕之后,bits 数组中的 40 个比特位的第 0 位就会被置位 0!

running 数组中每个下标对应的进程队列都执行完了一遍,这就意味着,bitmap 中的 40 个比特位都被置 0 了!我们就能在近乎 O(1) 的时间内,判断出 running 数组中是否还存在未被执行过的进程。当判断出 running 数组中没有未被执行过的进程时(isEmpty == 0),我们就交换 run 指针和 wait 指针,此时 CPU 就可以继续执行处于 R 状态的进程了

  • 如果我们不使用位图来判断 running 数组中是否有未执行过的进程,那么时间复杂度比较高了!
  • 可以看出 run 指针始终指向那个正真的 running 数组(因为交换会使得 run 指向我们刚才在结构体中定义的 waiting 数组,但是交换之后,这个 waiting 数组才是正真的 running 数组,你应该能懂我的意思吧!),同理,wait 指针始终指向那个正真的 waiting 数组。

以上讲解的进程调度算法称为:linux 内核 2.6 的 O(1) 调度算法!

知识点小结:

  • 什么是进程优先级?
  • 为什么要有进程优先级?
  • 如何查看和修改进程的优先级?
  • Linux 内核 2.6 版本是如何根据进程优先级调度进程的?

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/219311.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

网络运维与网络安全 学习笔记2023.12.5

网络运维与网络安全 学习笔记 第三十五天 今日目标 su用户切换、sudo命令提权、部署动态Web应用 数据库安全加固、Web安全加固 网络监控基础、配置zabbix主控机、配置zabbix被控机 管理监控项、监控结果分析 su用户切换 su机制介绍及用法 Linux安全基线 指的是使Linux各项…

哈希表【1】

文章目录 🤔0.哈希表🌼1. 两数之和🌻1. 题目🌷2. 算法原理🌺3. 代码实现 🍈面试题 01.02. 判定是否互为字符重排🍌1. 题目🍏2. 算法原理🍓3. 代码实现 🤔0.哈…

2024 年甘肃省职业院校技能大赛中职组 电子与信息类“网络安全”赛项竞赛样题-C卷

2024 年甘肃省职业院校技能大赛中职组 电子与信息类“网络安全”赛项竞赛样题-C卷 2024 年甘肃省职业院校技能大赛中职组 电子与信息类“网络安全”赛项竞赛样题-C卷A模块基础设施设置/安全加固(200分)A 模块基础设施设置/安全加固(200 分&am…

一个跨平台、跨空间支持多用户的远程云备份系统

多可云备份系统用于将一台服务器上的数据,高速备份到另一台或多台服务器上。无论这些服务器都在同一个局域网内,还是都在云服务器上,或者是分别在局域网内和云服务器上,使用多可云备份系统,都能够高速、高效、精确地完…

AntV和AntD之间的区别与联系

前言:最近在调研前端的一些框架,技术栈主要是用react,所以找到了2个十分相似解决方案,拿来对比一下(antd和antv都是基于react) antd对比antv antd antv 解决方案企业级 UI 设计语言数据可视化解决方案提供…

每日一练 | 华为认证真题练习Day142

1、路由器的主要功能,以下说法错误的是?(多选) A. 通过多种协议建立路由表 B. 根据路由表指导数据转发 C. 根据收到数据包的源IP地址进行转发 D. 实现相同网段设备之间相互通信 2、管理员发现无法通过TFTP传输文件到华为AR200…

【设计模式】策略模式设计-电影票打折功能

任务二:使用策略模式设计电影票打折功能 某电影院售标系统为不同类型的用户提供了不同的打折方式(Discount),学生凭学生证可享受8折优惠**(StudentDiscount),儿童可享受减免10元的优惠&#xf…

使用gunicorn部署django项目时,发现静态文件加载失败问题

本文主要介绍如何配置Niginx加载Django的静态资源文件,也就是Static 1、首先需要将Django项目中的Settings.py 文件中的两个参数做以下设置: STATIC_URL /static/ STATIC_ROOT os.path.join(BASE_DIR, static) 2、将 STATICFILES_DIRS [ os.p…

开关电源有哪些EMI整改?|深圳比创达电子EMC

某控制产品在进行辐射发射测试时,发现测试结果超标,辐射发射测试结果如下图所示: 控制产品在去掉发射源之前,就在各外部端口采取了各种滤波措施,结果并无明显作用,即使把所有相关外部引线全部拿走(只剩下电…

js 防抖函数、节流函数

/** 节流函数 */ export function throttle(func, wait 100) {let isDoing falsereturn function (...rest) {if (isDoing) returnisDoing truesetTimeout(() > {func(...rest)isDoing false}, wait)} }/** 防抖函数 */ export function debounce(func, wait 100) {let…

微信小程序开发:地图路线规划全流程,超详细!!!(包括遇到的问题解决)

目录 效果展示 第一章 准备阶段 1.1 使用uniapp搭建微信小程序 1.2 条件1:appId(微信小程序appId) 1.3 条件2:key(腾讯位置服务申请的key) 1.4 条件3:插件appId(微信小程序插件…

C语言每日一题(41)循环队列

力扣 622 循环队列 题目描述 设计你的循环队列实现。 循环队列是一种线性数据结构,其操作表现基于 FIFO(先进先出)原则并且队尾被连接在队首之后以形成一个循环。它也被称为“环形缓冲器”。 循环队列的一个好处是我们可以利用这个队列之前…

分布式版本管理系统---->Git(Linux---centos(保姆式)讲解1)

文章目录: 1:什么是Git以及作用 2.Git的基本操作过程(创建git仓库,配置仓库的配置) 3.git的工作区,暂存区,版本库的关系 4.将文件添加到版本库:git add 与git commit -m命令 5.git log查看日志的引入 6.查看.git文件中的内容 7.修改文件内容查…

图扑数字孪生压缩空气储能管控平台

压缩空气储能在解决可再生能源不稳定性和提供可靠能源供应方面具有重要的优势。压缩空气储能,是指在电网负荷低谷期将电能用于压缩空气,在电网负荷高峰期释放压缩空气推动汽轮机发电的储能方式。通过提高能量转换效率、增加储能密度、快速启动和调节能力…

探索什么样的导线,适合做433的天线

​​​​​​一、理论基础 (3 封私信 / 18 条消息) 为什么天线的材质会影响接收电磁波的效果? - 知乎 (zhihu.com) 电感基础3——RLC电路,帮助你轻松理解“阻抗”的概念 - 知乎 (zhihu.com) 一文读懂介电性能---介电常数 - 知乎 (zhihu.com) 433MHz 至…

亚马逊,shopee,lazada自养号测评补单,保护店铺信誉提升自然流量

测评补单对跨境电商卖家来说,是运营店铺的重要手段之一。一个产品想要有更好的曝光、更高的转化率,需要有一个好的Listing排名。Review在各平台Listing中占据着较高的权重,一个好的Review能给用户带来良好的观感,使用户对产品的信…

【EI会议征稿】第五届人工智能、网络与信息技术国际学术会议(AINIT 2024)

第五届人工智能、网络与信息技术国际学术会议(AINIT 2024) 第五届人工智能、网络与信息技术国际学术会议(AINIT 2024)将于2024年3月22-24日在中国南京举行。本届会议将主要关注人工智能、网络与信息技术面临的新的挑战问题和研究…

使用 kubeadm 部署 Kubernetes 集群(三)kubeadm 初始化 k8s 证书过期解决方案

一、延长k8s证书时间 查看 apiserver 证书有效时间:默认是一年的有效期 [rootxuegod63 ~]# openssl x509 -in /etc/kubernetes/pki/apiserver.crt -noout -text |grep Not 延长证书过期时间 1.把 update-kubeadm-cert.sh 文件上传到 xuegod63 节点 vim update-…

写给初学者的 HarmonyOS 教程 -- 页面路由(router)

页面路由(router)是指在应用程序中实现不同页面之间的跳转和数据传递。 HarmonyOS 提供了 Router 模块,通过不同的 url 地址,可以方便地进行页面路由,轻松地访问不同的页面。 类似这样的效果: 页面跳转是…

代理服务器如何保护用户隐私和安全?

目录 前言 一、代理服务器的工作原理 二、代理服务器的隐私保护机制 1. IP地址隐藏 2. 安全加密 3. 访问控制 三、代理服务器的安全问题 1. 黑客攻击 2. 版本漏洞 3. 恶意软件 四、总结 前言 代理服务器是一种位于用户与服务器之间的中介,可以隐藏用户的…