【Linux进程特别篇】深度理解辨识僵尸进程和孤儿进程
---------------------------------------------------------------------------------------------------------------------------------
每日鸡汤:每一份坚持都是成功的积累,只要相信自己,总会遇到惊喜。
-------------------------------------------------------------------------------------------------------------------------------
目录
编辑
一:进程的状态
二:僵尸进程
2.1:僵尸进程的定义与特点
2.2:僵尸进程怎样产生的,如何避免出现僵尸进程?
三:孤儿进程
2.1:孤儿进程的定义与特点
2.2:孤儿进程怎样产生的,如何避免出现孤儿进程?
四:区分辨识僵尸进程和孤儿进程
4.1:僵尸进程和孤儿进程的实例源码
4.1.1:创建僵尸进程
4.1.2:创建孤儿进程
4.2:总结区别僵尸进程和孤儿进程
一:进程的状态
进程在操作系统中可以处于多种状态,这些状态反映了进程在生命周期中的不同阶段。通常,最基本的进程状态模型包括三种状态:就绪(Ready)、运行(Running)和阻塞(Blocked),有时也称为等待(Waiting),但是在Linux中还有一些其他的进程状态,比如暂停态,僵尸态,孤儿态等
即,僵尸进程和孤儿进程是Unix/Linux操作系统中两种特殊类型的进程状态。它们都涉及到父进程与子进程之间的关系 。
为了深度理解父子进程,了解僵尸进程和孤儿进程是学习道路上必不可少的一个阶段。
二:僵尸进程
2.1:僵尸进程的定义与特点
僵尸进程的定义:
僵尸进程是一个已经完成执行(即其所有代码都已运行完毕),但其父进程尚未读取其退出状态的进程。
僵尸进程的特点:
- 僵尸进程不再占用任何CPU资源或内存资源,但它仍然在系统进程表中占有一项,保留了一些信息(如进程ID、退出状态等)。
- 如果不及时处理僵尸进程,系统中的进程表会逐渐被填满,最终可能导致无法创建新的进程。
2.2:僵尸进程怎样产生的,如何避免出现僵尸进程?
僵尸进程由很多的危害,那么僵尸进程是如何产生的呢
当一个子进程终止时,它会向其父进程发送一个信号(通常是 SIGCHLD),通知父进程它的退出状态。如果父进程没有调用 wait() 或 waitpid() 来读取子进程的退出状态,子进程就会变成僵尸进程。
避免出现僵尸进程:
父进程尽快通过wait()
或waitpid()
来收集子进程的状态信息,这样内核就可以回收子进程的PCB。如果父进程不这样做,可以考虑发送信号给父进程强制其处理,或者重启父进程。
三:孤儿进程
2.1:孤儿进程的定义与特点
孤儿进程的定义:
如果一个进程的父进程在它之前终止了,而该进程自己仍然存活并运行着,这样的进程被称为孤儿进程。
孤儿进程的特点:
- 在现代Unix/Linux系统中,一旦某个进程成为孤儿进程,init进程(进程号为1)会自动收养这些孤儿进程。
- init进程会负责等待孤儿进程结束,并且清理它们的状态信息。
- 孤儿进程继续正常运行,直到它们自然终止。
2.2:孤儿进程怎样产生的,如何避免出现孤儿进程?
孤儿进程的产生:
- 父进程在子进程之前退出:当一个进程(父进程)创建了一个或多个子进程后,如果父进程在它的所有子进程之前终止了,那么这些子进程就变成了孤儿进程。这是因为每个进程都有一个父进程,而一旦父进程不再存在,子进程就会失去它们的父进程。
- 父进程被强制终止:有时候,父进程可能因为某种原因被系统管理员或者通过其他程序(如使用kill命令)强制终止。如果此时有活动的子进程,那么这些子进程也会变成孤儿进程。
- 父进程崩溃:如果父进程由于编程错误或者其他问题而崩溃,同样会导致其子进程成为孤儿进程。
- 父进程主动放弃子进程:在某些情况下,父进程可能会调用特定的函数(例如prctl(PR_SET_PDEATHSIG, SIGKILL))来设置自己死亡时向子进程发送信号,从而让子进程知道自己的父进程已经不存在,并采取相应的行动。但如果不这样做,子进程仍会成为孤儿
避免出现孤儿进程:
通常不需要特别处理孤儿进程,因为init进程会接管它们。但如果希望避免产生孤儿进程,可以在编写程序时确保父进程妥善地管理其子进程的生命周期,例如使用信号处理器来捕获父进程的退出信号并在退出前清理子进程。
四:区分辨识僵尸进程和孤儿进程
4.1:僵尸进程和孤儿进程的实例源码
4.1.1:创建僵尸进程
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>int main()
{pid_t id = fork();if(id == 0){//子进程int cnt = 5;while(cnt){printf("我是子进程,pid: %d, ppid: %d, cnt: %d\n",getpid(),getppid(),cnt);cnt--;sleep(1);}exit(0);}else{while(1){printf("我是父进程,pid: %d, ppid: %d\n",getpid(),getppid());sleep(1);}}return 0;
}
父进程还没有运行完,而子进程运行完了,子进程的资源没有被父进程回收。
查看实例情况:
4.1.2:创建孤儿进程
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>int main()
{pid_t id = fork();if(id == 0){//子进程int cnt = 500;while(cnt){printf("我是子进程,pid: %d, ppid: %d, cnt: %d\n",getpid(),getppid(),cnt);cnt--;sleep(1);}exit(0);}else{int cnt1 = 5;while(cnt1--){printf("我是父进程,pid: %d, ppid: %d, cnt1 = %d\n",getpid(),getppid(), cnt1);sleep(1);}}return 0;
}
当父进程运行完毕回收,而子进程却还正在运行。此时该子进程就被称为孤儿进程。因为孤儿进程的父进程已经被回收了,所以为了保障到时候该子进程运行结束有父进程回收他的资源(不让他成为僵尸进程),操作系统(init进程,进程号为1)会 “收养” 该子进程,所以该子进程的父进程就是init进程,其父进程号为1,那么该子进程就被称为孤儿进程。
查看实例情况:
4.2:总结区别僵尸进程和孤儿进程
子进程退出,父进程还在运行,但父进程没有读取子进程状态,子进程进入僵尸状态,子进程就称之为“僵尸进程”
父进程先退出,子进程还在运行,子进程被操作系统“领养”,子进程就称之为“孤儿进程”
相关文章:

【Linux进程特别篇】深度理解辨识僵尸进程和孤儿进程
--------------------------------------------------------------------------------------------------------------------------------- 每日鸡汤:每一份坚持都是成功的积累,只要相信自己,总会遇到惊喜。 -----------------------------…...

喜报|超维机器人荣获昇腾AI创新大赛铜奖
近日,在备受瞩目的昇腾AI创新大赛中,超维机器人凭借扎实的技术实力和创新产品,荣获大赛铜奖。这一荣誉不仅展现了超维机器人在智能巡检领域的技术创新与突破,也标志着超维机器人的智能巡检解决方案在人工智能领域获得了广泛认可&a…...
从五种架构风格推导出HTTP的REST架构
在分布式系统中,架构风格(Architectural Style)决定了系统组件如何交互、通信、存储和管理数据。每种架构风格都有其独特的特性和适用场景。本文将从五种典型的架构风格出发,逐步探讨它们如何影响了REST(Representational State Transfer,表述性状态转移)架构风格的设计…...

vue-h5:在h5中实现相机拍照加上身份证人相框和国徽框
方案1:排出来照片太糊了,效果不好 1.基础功能 参考: https://blog.csdn.net/weixin_45148022/article/details/135696629 https://juejin.cn/post/7327353533618978842?searchId20241101133433B2BB37A081FD6A02DA60 https://www.freesio…...

免费HTML模板和CSS样式网站汇总
HTML模板:(注意版权,部分不可商用) 1、Tooplate,免费HTML模板下载 Download 60 Free HTML Templates for your websitesDownload 60 free HTML website templates or responsive Bootstrap templates instantly from T…...
Mac打开time machine(时间机器)备份特殊文件
Mac 打开time machine(时间机器)备份特殊文件 设置“时间机器”的作用具体操作办法 前言:今天在使用Nas同步文件时发现有部分重要文件没有同步,为了省事手动拖拽复制文件,导致其中一份非常重要的文件丢失,尝…...

Qt 学习第十六天:文件和事件
一、创建widget对象(文件) 二、设计ui界面 放一个label标签上去,设置成box就可以显示边框了 三、新建Mylabel类 四、提升ui界面的label标签为Mylabel 五、修改mylabel.h,mylabel.cpp #ifndef MYLABEL_H #define MYLABEL_H#incl…...
nvm 切换 Node.js 版本
nvm 切换 Node.js 版本 0. nvm 安装1. 查看装了哪些 Node.js 版本2. 安装 Node.js 版本安装最新稳定版本.安装个18 3. 切换 Node.js 版本4. 设置默认 Node.js 版本5. 卸载 Node.js 版本6.与项目的配合使用参考资料 0. nvm 安装 安装教程就不写了,直接看别人的。 脚…...

AI绘图最强软件stable diffusion,一文带你迅速了解!
有需要stable diffusion整合包可以扫描下方,免费获取 01 — 什么是 SD Stable Difusion(简称 SD) 其三种概念。 1.用来指代稳定扩散(Stable Diffusion) 技术,如 Midjourney是基于Stable Difusion技术实现的就是指它运用了 Stable Diffusion 的技术原理。 …...

VMware重磅官宣!Workstation和Fusion彻底全部免费:支持商用
VMware 官网宣布:VMware Workstation Pro: Now Available Free for Personal Use 别问,问就是正版用户!!! VMware宣布,其桌面虚拟化产品VMware Workstation和VMware Fusion将对所有用户彻底免费࿰…...
CCS 学习记录
1.导入项目 在CCS菜单中选择Project->Import Existing CCS Eclipse Project,点击Browse找到CCS workspace所在文件夹,点击OK,CCS会自动将所选文件夹及其子文件夹下所有的CCS Projects列出。从列表中找到所要导入的项目文件夹,…...
241112.学习日志——[CSDIY] Cpp零基础速成 [01]
CSDIY:这是一个非科班学生的努力之路,从今天开始这个系列会长期更新,(最好做到日更),我会慢慢把自己目前对CS的努力逐一上传,帮助那些和我一样有着梦想的玩家取得胜利!!&…...

94.【C语言】数据结构之双向链表的初始化,尾插,打印和尾删
目录 1.双向链表 2.结构体的定义 3.示意图 3.代码示例 1.双向链表的尾插 示意图 代码 main.c List.h List.c 详细分析代码的执行过程 双向链表的初始化 2.双向链表的打印 代码 3.双向链表的尾删 1.双向链表 以一种典型的双向链表为例:带头双向循环链表(带头:带…...
learn-F12 Performance(性能)前端性能分析(LCP,CLS,INP)
1.前言 在浏览器开发者工具(F12)中,本地指标(Local Metrics)包括LCP( Largest Contentful Paint)、CLS( Cumulative Layout Shift)和INP( Interaction to Nex…...
XCZU47DR-2FSVE1156
XCZU47DR-2FSVE1156 芯片概述 XCZU47DR-2FSVE1156 是一款由 Xilinx 公司生产的 Zynq UltraScale™ RFSoC 芯片。该芯片集成了多种高性能组件,包括四核 ARM Cortex-A53 MPCore™ 和双核 ARM Cortex™-R5,提供了强大的计算能力和灵活性。它还具备丰富的连…...

物联网低功耗广域网LoRa开发(一):LoRa物联网行业解决方案
一、LoRa的优势以及与其他无线通信技术对比 (一)LoRa的优势 1、164dB链路预算 、距离>15km 2、快速、灵活的基础设施易组网且投资成本较少 3、LoRa节点模块仅用于通讯电池寿命长达10年 4、免牌照的频段 网关/路由器建设和运营 、节点/终端成本低…...
【LeetCode】【算法】23. 合并K个升序链表
LeetCode 23. 合并K个升序链表 题目描述 给你一个链表数组,每个链表都已经按升序排列。 请你将所有链表合并到一个升序链表中,返回合并后的链表。 思路 思路:用小根堆解,很强 创建一个小根堆,排序规则为小根堆排序…...

python3的基本数据类型:Dictionary(字典)的创建
一. 简介 本文开始简单学习一下 python3中的一种基本数据类型:Dictionary(字典)。 字典(dictionary)是Python中另一个非常有用的内置数据类型。 二. python3的基本数据类型:Dictionary(字典&…...

【C++】string模拟实现
各位读者老爷好,俺最近在学习string的一些知识。为了更好的了解string的结构,俺模拟实现了一个丐版string,有兴趣的老爷不妨垂阅!!! 目录 1.string类的定义 2.模拟实现成员函数接口 2.1.constructor&am…...

Springboot 使用EasyExcel导出含图片并设置样式的Excel文件
Springboot 使用EasyExcel导出含图片并设置样式的Excel文件 Excel导出系列目录:★★★★尤其注意:引入依赖创建导出模板类逻辑处理controllerservice 导出效果总结 Excel导出系列目录: 【Springboot 使用EasyExcel导出Excel文件】 【Springb…...
conda相比python好处
Conda 作为 Python 的环境和包管理工具,相比原生 Python 生态(如 pip 虚拟环境)有许多独特优势,尤其在多项目管理、依赖处理和跨平台兼容性等方面表现更优。以下是 Conda 的核心好处: 一、一站式环境管理:…...
【杂谈】-递归进化:人工智能的自我改进与监管挑战
递归进化:人工智能的自我改进与监管挑战 文章目录 递归进化:人工智能的自我改进与监管挑战1、自我改进型人工智能的崛起2、人工智能如何挑战人类监管?3、确保人工智能受控的策略4、人类在人工智能发展中的角色5、平衡自主性与控制力6、总结与…...
逻辑回归:给不确定性划界的分类大师
想象你是一名医生。面对患者的检查报告(肿瘤大小、血液指标),你需要做出一个**决定性判断**:恶性还是良性?这种“非黑即白”的抉择,正是**逻辑回归(Logistic Regression)** 的战场&a…...

智慧工地云平台源码,基于微服务架构+Java+Spring Cloud +UniApp +MySql
智慧工地管理云平台系统,智慧工地全套源码,java版智慧工地源码,支持PC端、大屏端、移动端。 智慧工地聚焦建筑行业的市场需求,提供“平台网络终端”的整体解决方案,提供劳务管理、视频管理、智能监测、绿色施工、安全管…...

Docker 运行 Kafka 带 SASL 认证教程
Docker 运行 Kafka 带 SASL 认证教程 Docker 运行 Kafka 带 SASL 认证教程一、说明二、环境准备三、编写 Docker Compose 和 jaas文件docker-compose.yml代码说明:server_jaas.conf 四、启动服务五、验证服务六、连接kafka服务七、总结 Docker 运行 Kafka 带 SASL 认…...

(二)原型模式
原型的功能是将一个已经存在的对象作为源目标,其余对象都是通过这个源目标创建。发挥复制的作用就是原型模式的核心思想。 一、源型模式的定义 原型模式是指第二次创建对象可以通过复制已经存在的原型对象来实现,忽略对象创建过程中的其它细节。 📌 核心特点: 避免重复初…...

Nuxt.js 中的路由配置详解
Nuxt.js 通过其内置的路由系统简化了应用的路由配置,使得开发者可以轻松地管理页面导航和 URL 结构。路由配置主要涉及页面组件的组织、动态路由的设置以及路由元信息的配置。 自动路由生成 Nuxt.js 会根据 pages 目录下的文件结构自动生成路由配置。每个文件都会对…...

【论文阅读28】-CNN-BiLSTM-Attention-(2024)
本文把滑坡位移序列拆开、筛优质因子,再用 CNN-BiLSTM-Attention 来动态预测每个子序列,最后重构出总位移,预测效果超越传统模型。 文章目录 1 引言2 方法2.1 位移时间序列加性模型2.2 变分模态分解 (VMD) 具体步骤2.3.1 样本熵(S…...

ios苹果系统,js 滑动屏幕、锚定无效
现象:window.addEventListener监听touch无效,划不动屏幕,但是代码逻辑都有执行到。 scrollIntoView也无效。 原因:这是因为 iOS 的触摸事件处理机制和 touch-action: none 的设置有关。ios有太多得交互动作,从而会影响…...
Swagger和OpenApi的前世今生
Swagger与OpenAPI的关系演进是API标准化进程中的重要篇章,二者共同塑造了现代RESTful API的开发范式。 本期就扒一扒其技术演进的关键节点与核心逻辑: 🔄 一、起源与初创期:Swagger的诞生(2010-2014) 核心…...