【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…...
docker详细操作--未完待续
docker介绍 docker官网: Docker:加速容器应用程序开发 harbor官网:Harbor - Harbor 中文 使用docker加速器: Docker镜像极速下载服务 - 毫秒镜像 是什么 Docker 是一种开源的容器化平台,用于将应用程序及其依赖项(如库、运行时环…...
k8s从入门到放弃之Ingress七层负载
k8s从入门到放弃之Ingress七层负载 在Kubernetes(简称K8s)中,Ingress是一个API对象,它允许你定义如何从集群外部访问集群内部的服务。Ingress可以提供负载均衡、SSL终结和基于名称的虚拟主机等功能。通过Ingress,你可…...
【HarmonyOS 5.0】DevEco Testing:鸿蒙应用质量保障的终极武器
——全方位测试解决方案与代码实战 一、工具定位与核心能力 DevEco Testing是HarmonyOS官方推出的一体化测试平台,覆盖应用全生命周期测试需求,主要提供五大核心能力: 测试类型检测目标关键指标功能体验基…...
【大模型RAG】Docker 一键部署 Milvus 完整攻略
本文概要 Milvus 2.5 Stand-alone 版可通过 Docker 在几分钟内完成安装;只需暴露 19530(gRPC)与 9091(HTTP/WebUI)两个端口,即可让本地电脑通过 PyMilvus 或浏览器访问远程 Linux 服务器上的 Milvus。下面…...
sqlserver 根据指定字符 解析拼接字符串
DECLARE LotNo NVARCHAR(50)A,B,C DECLARE xml XML ( SELECT <x> REPLACE(LotNo, ,, </x><x>) </x> ) DECLARE ErrorCode NVARCHAR(50) -- 提取 XML 中的值 SELECT value x.value(., VARCHAR(MAX))…...
高防服务器能够抵御哪些网络攻击呢?
高防服务器作为一种有着高度防御能力的服务器,可以帮助网站应对分布式拒绝服务攻击,有效识别和清理一些恶意的网络流量,为用户提供安全且稳定的网络环境,那么,高防服务器一般都可以抵御哪些网络攻击呢?下面…...
浅谈不同二分算法的查找情况
二分算法原理比较简单,但是实际的算法模板却有很多,这一切都源于二分查找问题中的复杂情况和二分算法的边界处理,以下是博主对一些二分算法查找的情况分析。 需要说明的是,以下二分算法都是基于有序序列为升序有序的情况…...
【HarmonyOS 5 开发速记】如何获取用户信息(头像/昵称/手机号)
1.获取 authorizationCode: 2.利用 authorizationCode 获取 accessToken:文档中心 3.获取手机:文档中心 4.获取昵称头像:文档中心 首先创建 request 若要获取手机号,scope必填 phone,permissions 必填 …...
jmeter聚合报告中参数详解
sample、average、min、max、90%line、95%line,99%line、Error错误率、吞吐量Thoughput、KB/sec每秒传输的数据量 sample(样本数) 表示测试中发送的请求数量,即测试执行了多少次请求。 单位,以个或者次数表示。 示例:…...
从物理机到云原生:全面解析计算虚拟化技术的演进与应用
前言:我的虚拟化技术探索之旅 我最早接触"虚拟机"的概念是从Java开始的——JVM(Java Virtual Machine)让"一次编写,到处运行"成为可能。这个软件层面的虚拟化让我着迷,但直到后来接触VMware和Doc…...

