【Linux篇】进程状态(僵尸进程,孤儿进程),优先级与调度机制

1. 前文铺垫

进程状态是task_struct内的一个整数;进行:进程在调度队列中,进程的状态都是running,阻塞:等待某种设备或者资源就绪。进程是一个队列,设备也是一个队列,当我们读磁盘,读网卡的时候,如果对应设备未就绪那么进程就要阻塞等待了。进程状态变化的表现之一就是要在不同的队列中进行流动,本质都是数据结构的增删查改!

理解内核链表

【Linux篇】进程状态(僵尸进程,孤儿进程),优先级与调度机制

如果一个类里面有多个next,prve,那么就可以把任何一个task_struct即属于运行队列,又属于全局链表,还可以把它放到二叉树中等。

【Linux篇】进程状态(僵尸进程,孤儿进程),优先级与调度机制

2. 进程状态

一个进程可以有几个状态(在Linux内核里,进程有时候也叫做任务)。

下面的状态在kernel源代码里定义:代码语言:javascript代码运行次数:0运行复制

/**The task state array is a strange "bitmap" of*reasons to sleep. Thus "running" is zero, and*you can test for combinations of others with*simple bit tests.*/static const char *const task_state_array[] = { "R (running)", /*0 */ "S (sleeping)", /*1 */ "D (disk sleep)", /*2 */ "T (stopped)", /*4 */ "t (tracing stop)", /*8 */ "X (dead)", /*16 */ "Z (zombie)", /*32 */};

R 运行或可运行 (Running 或 Runnable)状态描述: 进程正在CPU上执行,或在运行队列中等待调度。触发场景: 进程处于活动状态,正在执行或准备执行。S 可中断睡眠(Interruptible Sleep)状态描述: 进程在等待事件完成(如I/O操作、信号),可被信号中断。触发场景: 例如调用 sleep()read() 等阻塞操作时。D 不可中断睡眠(Uninterruptible Sleep)状态描述: 进程等待不可中断的操作(如硬件I/O),不响应信号。触发场景: 常见于磁盘I/O或某些内核操作,需等待操作完成。T 停止(Stopped)状态描述: 进程被信号(如 SIGSTOPSIGTSTP)暂停,需 SIGCONT 恢复。触发场景: 手动暂停进程(如按 Ctrl+Z)或调试时。Z 僵尸(Zombie)状态描述: 进程已终止,但父进程未调用 wait() 回收资源。触发场景: 父进程未正确处理子进程退出,导致残留进程描述符。t 追踪状态(Tracing Stop)状态描述: 进程被调试器(如 gdb)跟踪时暂停,属于停止状态的一种。触发场景: 调试器设置断点或单步执行时。X 死亡(Dead)状态描述: 子进程结束之后,父进程获取子进程信息之前。触发场景: 父进程已回收子进程状态,短暂存在后消失。2.1 进程状态查看

命令: ps aux / ps axj

2.2 僵尸进程

【Linux篇】进程状态(僵尸进程,孤儿进程),优先级与调度机制

僵死状态(Zombies)是一个比较特殊的状态。当进程退出并且父进程(使用wait()系统调用)没有读取到子进程退出的返回代码时就会产生僵死(尸)进程。僵死进程会以终止状态保持在进程表中,并且会一直在等待父进程读取退出状态代码。只要子进程退出,父进程还在运行,但父进程没有读取子进程状态,子进程进入Z状态。2.3 僵尸进程危害进程的退出状态必须被维持下去,因为他要告诉关心它的进程(父进程),你交给我的任务,我 办的怎么样了。可父进程如果一直不读取,那子进程就一直处于Z状态?是的!维护退出状态本身就是要用数据维护,也属于进程基本信息,所以保存在task_struct(PCB)中,换句话说,Z状态⼀直不退出,PCB一直都要维护?是的!那一个父进程创建了很多子进程,就是不回收,是不是就会造成内存资源的浪费?是的!因为数据结构对象本身就要占用内存,C语言中定义一个结构体变量(对象),是要在内存的某个位置进行开辟空间,那就会存在内存泄漏?是的! 如何避免呢?我们后期讲。2.4 孤儿进程我们先来创建一段代码

【Linux篇】进程状态(僵尸进程,孤儿进程),优先级与调度机制

代码运行后,子进程一直运行,父进程运行5秒后退出

【Linux篇】进程状态(僵尸进程,孤儿进程),优先级与调度机制

这个1号进程是谁呢?top一下,我们可以看到它是systemd

【Linux篇】进程状态(僵尸进程,孤儿进程),优先级与调度机制

我们继续查一下这个systemd

【Linux篇】进程状态(僵尸进程,孤儿进程),优先级与调度机制

为什么子进程会被1(systemd)号进程领养呢?如果不领养会出现什么问题呢? 答案是如果不被领养,那么这个子进程就进入僵尸进程,有可能会造成内存泄漏父进程为什么不会变成孤儿进程或者僵尸进程呢? 答案是父进程也有自己的父进程,父进程的父进程就是bash一旦进程变成孤儿进程,它就会被1号进程领养,变成后台进程,这时候Ctrl c就杀不掉它了,我们只能使用kill来杀死。3. 进程优先级3.1 概念cpu资源分配的先后顺序,就是指进程的优先级(priority)。目标资源稀缺,导致要通过优先级确认谁先谁后的问题。优先权高的进程有优先执行权利。配置进程优先级对多任务环境的linux很有用,可以改善系统性能。还可以把进程运行到指定的CPU上,这样一来,把不重要的进程安排到某个CPU,可以大大改善系统整体性能。优先级 vs 权限:优先级是能得到资源,先后的问题,权限是能否得到资源的问题

✏️优先级其实也是一种数字,是task_struct中的一种属性,数字值越低,优先级越高 ,基于时间片的分时操作系统,优先级未来可能变化,但变化的幅度不能太大

3.2 查看系统进程命令ps -al,其中a表示所有,l表示详细信息。我们上上面代码中的父进程不再退出,父子进程一直运行,再运行代码

【Linux篇】进程状态(僵尸进程,孤儿进程),优先级与调度机制

linux系统中,每个用户都有一个UID,linux中识别用户就是用UID识别的。

UID:代表执行者的身份PID:代表这个进程的代号PPID:代表这个进程是由哪个进程发展衍生出来的,亦即父进程的代号PRI:代表这个进程可被执行的优先级,其值越小越早被执行。进程优先级默认:80NI:代表这个进程优先级的修正数据,nice值 ✏️进程真实的优先级 = PRI(默认) + NI ✏️PRI(new) = PRI(old) + nice所以,调整进程优先级,在Linux下,就是调整进程nicenice其取值范围是-2019,一共40个级别。linux进程优先级范围[60,99]UID,命令ls -ln

【Linux篇】进程状态(僵尸进程,孤儿进程),优先级与调度机制

sp用户对应的UID就是1001,文件创建的时候会把这个UID保存起来表明这个文件是谁创建的,进程创建的时候也会把UID保存起来表明进程是谁创建的。 ? 所以当我们访问一个文件时,系统怎么识别出我们是拥有者,所属组,或者other呢,我们访问文件时本质就是进程在访问文件,进程怎么知道我们是谁呢?答案是是谁启动的这个进程,进程就知道这个人的UID,这个文件是谁创建的这个文件的UID就有了,所以一个进程将来拿着它的UID和文件的UID做对比,相等了就是拥有者,不相等查下一个,两个都不相等就是 other。 ✏️linux系统中,访问任何资源都是进程访问,进程就代表用户。

豆包AI编程 豆包AI编程

豆包推出的AI编程助手

豆包AI编程 483 查看详情 豆包AI编程 3.3 查看进程优先级的命令

top命令更改已存在进程的nice

top 进入top后按“r”‒>输入进程PID‒>输入nice值 其他调整优先级的命令:nicerenice linux调整优先级的系统调用 3.4 补充概念-竞争、独立、并行、并发竞争性: 系统进程数目众多,而CPU资源只有少量,甚至1个,所以进程之间是具有竞争属性的。为了高效完成任务,更合理竞争相关资源,便具有了优先级独立性: 多进程运行,需要独享各种资源,多进程运行期间互不干扰并行: 多个进程在多个CPU下分别,同时进行运行,这称之为并行并发: 多个进程在⼀个CPU下采用进程切换的方式,在一段时间之内,让多个进程都得以推进,称之为并发

【Linux篇】进程状态(僵尸进程,孤儿进程),优先级与调度机制

4. 进程切换

先谈两个问题:

死循环进程是如何运行的 我们平时在vs中写一个while(1)的死循环,一旦跑起来我们就会发现系统会变卡了,但是不会卡死。 a.一旦一个进程占有CPU,会把自己的代码跑完吗?不会!(除非这个代码很短)每个进程系统都会为它分配一个叫做时间片的东西。所以每一个进程拥有CPU资源都不是永久性的,而是临时性的。 b.死循环进程不会打死进程,因为死循环进程不会一直占用CPU!cpu,寄存器 cpu执行一个进程的时候就和PCB的关系不大了,cpu重点是访问的是进程的代码和数据,所以cpu会访问当前进程的代码和数据,为了能够处理一条一条的代码和数据,所以cpu中会存在很多的寄存器,每个寄存器在cpu内部都有着临时保存数据的任务,所以当进程再跑时,寄存器就会被填上临时值,有的是计算结果,浮点数计算有没有错误等。 结论: a.寄存器就是cpu内部的临时空间 b. 寄存器 != 寄存器里面的数据

进程如何切换? CPU上下文切换:其实际含义是任务切换,或者CPU寄存器切换。当多任务内核决定运行另外的任务时,它保存正在运行任务的当前状态,也就是CPU寄存器中的全部内容。这些内容被保存在任务自己的堆栈中,入栈工作完成后就把下一个将要运行的任务的当前状况从该任务的栈中重新装入CPU寄存器,并开始下一个任务的运行,这一过程就是context switch

【Linux篇】进程状态(僵尸进程,孤儿进程),优先级与调度机制

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

保存在哪里? 保存到进程的task_struct里面如何区分新的进程和已经调度过的进程? 在task_struct中增加一个标记位。5.Linux2.6内核进程O(1)调度队列

【Linux篇】进程状态(僵尸进程,孤儿进程),优先级与调度机制

一个CPU拥有一个runqueue如果有多个CPU就要考虑进程个数的负载均衡问题优先级普通优先级:100〜139(我们都是普通的优先级,想想nice值的取值范围,可与之对应!)实时优先级:0〜99(不关心)活动队列时间片还没有结束的所有进程都按照优先级放在该队列nr_active:总共有多少个运行状态的进程queue[140]:一个元素就是一个进程队列,相同优先级的进程按照FIFO规则进行排队调度,所以,数组下标就是优先级!从该结构中,选择一个最合适的进程,过程是怎么的呢? a. 从0下标开始遍历queue[140] b. 找到第一个非空队列,该队列必定为优先级最高的队列 c. 拿到选中队列的第一个进程,开始运行,调度完成! d. 遍历queue[140]时间复杂度是常数!但还是太低效了!bitmap[5]:一共140个优先级,一共140个进程队列,为了提高查找非空队列的效率,就可以用5*32个比特位表示队列是否为空,这样,便可以大 大提高查找效率。

【Linux篇】进程状态(僵尸进程,孤儿进程),优先级与调度机制

过期队列过期队列和活动队列结构一模一样过期队列上放置的进程,都是时间片耗尽的进程当活动队列上的进程都被处理完毕之后,对过期队列的进程进行时间片重新计算active指针和expired指针active指针永远指向活动队列expired指针永远指向过期队列活动队列上的进程会越来越少,过期队列上的进程会越来越多,因为进程时间片到期时一直都存在的。在合适的时候,只要能够交换active指针和expired指针的内容,就相当于有具有了一批新的活动进程!

linux真是算法调度:O(1)调度算法 再次理解nice值:nice值是为了保证老进程的优先级不被强制改变,原本进程的优先级不改变,加上一个nice值,当本次调度完重新放入过期队列时,更新优先级,链入到指定位置。

以上就是【Linux篇】进程状态(僵尸进程,孤儿进程),优先级与调度机制的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/512964.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月9日 01:46:44
下一篇 2025年11月9日 01:49:58

相关推荐

  • 怎样用免费工具美化PPT_免费美化PPT的实用方法分享

    利用KIMI智能助手可免费将PPT美化为科技感风格,但需核对文字准确性;2. 天工AI擅长优化内容结构,提升逻辑性,适合高质量内容需求;3. SlidesAI支持语音输入与自动排版,操作便捷,利于紧急场景;4. Prezo提供多种模板,自动生成图文并茂幻灯片,适合学生与初创团队。 如果您有一份内容完…

    2025年12月6日 软件教程
    100
  • Pages怎么协作编辑同一文档 Pages多人实时协作的流程

    首先启用Pages共享功能,点击右上角共享按钮并选择“添加协作者”,设置为可编辑并生成链接;接着复制链接通过邮件或社交软件发送给成员,确保其使用Apple ID登录iCloud后即可加入编辑;也可直接在共享菜单中输入邮箱地址定向邀请,设定编辑权限后发送;最后在共享面板中管理协作者权限,查看实时在线状…

    2025年12月6日 软件教程
    200
  • REDMI K90系列正式发布,售价2599元起!

    10月23日,redmi k90系列正式亮相,推出redmi k90与redmi k90 pro max两款新机。其中,redmi k90搭载骁龙8至尊版处理器、7100mah大电池及100w有线快充等多项旗舰配置,起售价为2599元,官方称其为k系列迄今为止最完整的标准版本。 图源:REDMI红米…

    2025年12月6日 行业动态
    200
  • Linux中如何安装Nginx服务_Linux安装Nginx服务的完整指南

    首先更新系统软件包,然后通过对应包管理器安装Nginx,启动并启用服务,开放防火墙端口,最后验证欢迎页显示以确认安装成功。 在Linux系统中安装Nginx服务是搭建Web服务器的第一步。Nginx以高性能、低资源消耗和良好的并发处理能力著称,广泛用于静态内容服务、反向代理和负载均衡。以下是在主流L…

    2025年12月6日 运维
    000
  • Linux journalctl与systemctl status结合分析

    先看 systemctl status 确认服务状态,再用 journalctl 查看详细日志。例如 nginx 启动失败时,systemctl status 显示 Active: failed,journalctl -u nginx 发现端口 80 被占用,结合两者可快速定位问题根源。 在 Lin…

    2025年12月6日 运维
    100
  • 华为新机发布计划曝光:Pura 90系列或明年4月登场

    近日,有数码博主透露了华为2025年至2026年的新品规划,其中pura 90系列预计在2026年4月发布,有望成为华为新一代影像旗舰。根据路线图,华为将在2025年底至2026年陆续推出mate 80系列、折叠屏新机mate x7系列以及nova 15系列,而pura 90系列则将成为2026年上…

    2025年12月6日 行业动态
    100
  • Linux如何防止缓冲区溢出_Linux防止缓冲区溢出的安全措施

    缓冲区溢出可通过栈保护、ASLR、NX bit、安全编译选项和良好编码实践来防范。1. 使用-fstack-protector-strong插入canary检测栈破坏;2. 启用ASLR(kernel.randomize_va_space=2)随机化内存布局;3. 利用NX bit标记不可执行内存页…

    2025年12月6日 运维
    000
  • Linux如何优化系统性能_Linux系统性能优化的实用方法

    优化Linux性能需先监控资源使用,通过top、vmstat等命令分析负载,再调整内核参数如TCP优化与内存交换,结合关闭无用服务、选用合适文件系统与I/O调度器,持续按需调优以提升系统效率。 Linux系统性能优化的核心在于合理配置资源、监控系统状态并及时调整瓶颈环节。通过一系列实用手段,可以显著…

    2025年12月6日 运维
    000
  • Pboot插件数据库连接的配置教程_Pboot插件数据库备份的自动化脚本

    首先配置PbootCMS数据库连接参数,确保插件正常访问;接着创建auto_backup.php脚本实现备份功能;然后通过Windows任务计划程序或Linux Cron定时执行该脚本,完成自动化备份流程。 如果您正在开发或维护一个基于PbootCMS的网站,并希望实现插件对数据库的连接配置以及自动…

    2025年12月6日 软件教程
    000
  • Linux命令行中wc命令的实用技巧

    wc命令可统计文件的行数、单词数、字符数和字节数,常用-l统计行数,如wc -l /etc/passwd查看用户数量;结合grep可分析日志,如grep “error” logfile.txt | wc -l统计错误行数;-w统计单词数,-m统计字符数(含空格换行),-c统计…

    2025年12月6日 运维
    000
  • Linux命令行中fc命令的使用方法

    fc 是 Linux 中用于管理命令历史的工具,可查看、编辑并重新执行历史命令。输入 fc 直接编辑最近一条命令,默认调用 $EDITOR 打开编辑器修改后自动执行;通过 fc 100 110 或 fc -5 -1 可批量编辑指定范围的历史命令,保存后按序重跑;使用 fc -l 列出命令历史,支持起…

    2025年12月6日 运维
    000
  • 曝小米17 Air正在筹备 超薄机身+2亿像素+eSIM技术?

    近日,手机行业再度掀起超薄机型热潮,三星与苹果已相继推出s25 edge与iphone air等轻薄旗舰,引发市场高度关注。在此趋势下,多家国产厂商被曝正积极布局相关技术,加速抢占这一细分赛道。据业内人士消息,小米的超薄旗舰机型小米17 air已进入筹备阶段。 小米17 Pro 爆料显示,小米正在评…

    2025年12月6日 行业动态
    000
  • 「世纪传奇刀片新篇」飞利浦影音双11声宴开启

    百年声学基因碰撞前沿科技,一场有关声音美学与设计美学的影音狂欢已悄然引爆2025“双十一”! 当绝大多数影音数码品牌还在价格战中挣扎时,飞利浦影音已然开启了一场跨越百年的“声”活革命。作为拥有深厚技术底蕴的音频巨头,飞利浦影音及配件此次“双十一”精准聚焦“传承经典”与“设计美学”两大核心,为热爱生活…

    2025年12月6日 行业动态
    000
  • 荣耀手表5Pro 10月23日正式开启首销国补优惠价1359.2元起售

    荣耀手表5pro自9月25日开启全渠道预售以来,市场热度持续攀升,上市初期便迎来抢购热潮,一度出现全线售罄、供不应求的局面。10月23日,荣耀手表5pro正式迎来首销,提供蓝牙版与esim版两种选择。其中,蓝牙版本的攀登者(橙色)、开拓者(黑色)和远航者(灰色)首销期间享受国补优惠价,到手价为135…

    2025年12月6日 行业动态
    000
  • Vue.js应用中配置环境变量:灵活管理后端通信地址

    在%ignore_a_1%应用中,灵活配置后端api地址等参数是开发与部署的关键。本文将详细介绍两种主要的环境变量配置方法:推荐使用的`.env`文件,以及通过`cross-env`库在命令行中设置环境变量。通过这些方法,开发者可以轻松实现开发、测试、生产等不同环境下配置的动态切换,提高应用的可维护…

    2025年12月6日 web前端
    000
  • VSCode终端美化:功率线字体配置

    首先需安装Powerline字体如Nerd Fonts,再在VSCode设置中将terminal.integrated.fontFamily设为’FiraCode Nerd Font’等支持字体,最后配合oh-my-zsh的powerlevel10k等Shell主题启用完整美…

    2025年12月6日 开发工具
    000
  • JavaScript响应式编程与Observable

    Observable是响应式编程中处理异步数据流的核心概念,它允许随时间推移发出多个值,支持订阅、操作符链式调用及统一错误处理,广泛应用于事件监听、状态管理和复杂异步逻辑,提升代码可维护性与可读性。 响应式编程是一种面向数据流和变化传播的编程范式。在前端开发中,尤其面对复杂的用户交互和异步操作时,J…

    2025年12月6日 web前端
    000
  • Linux命令行中locate命令的快速查找方法

    locate命令通过查询数据库快速查找文件,使用-i可忽略大小写,-n限制结果数量,-c统计匹配项,-r支持正则表达式精确匹配,刚创建的文件需运行sudo updatedb更新数据库才能查到。 在Linux命令行中,locate 命令是快速查找文件和目录路径的高效工具。它不直接扫描整个文件系统,而是…

    2025年12月6日 运维
    000
  • 环境搭建docker环境下如何快速部署mysql集群

    使用Docker Compose部署MySQL主从集群,通过配置文件设置server-id和binlog,编写docker-compose.yml定义主从服务并组网,启动后创建复制用户并配置主从连接,最后验证数据同步是否正常。 在Docker环境下快速部署MySQL集群,关键在于合理使用Docker…

    2025年12月6日 数据库
    000
  • Linux文件系统rsync命令详解

    rsync通过增量同步高效复制文件,支持本地及远程同步,常用选项包括-a、-v、-z和–delete,结合SSH可安全传输数据,配合cron可实现定时备份。 rsync 是 Linux 系统中一个非常强大且常用的文件同步工具,能够高效地在本地或远程系统之间复制和同步文件与目录。它以“增量…

    2025年12月6日 运维
    000

发表回复

登录后才能评论
关注微信