孤儿进程与僵尸进程

进程退出

关于进程退出有两个函数

exit和 _exit:其主要差别是在于是否直接退出。

其流程主要区别如下:

孤儿进程(不存在危害)

  • 父进程运行结束,但子进程还在运行(未运行结束),这样的子进程就称为孤儿进程。
  • 每当出现一个孤儿进程的时候,内核就把孤儿进程的父进程设置为 init ,而 init 进程会循环地 wait()它的已经退出的子进程。这样,当一个孤儿进程凄凉地结束了其生命周期的时候,init 进程就会代表党和政府出面处理它的一切善后工作。

僵尸进程(有危害)

  1. 每个进程结束之后, 都会释放自己地址空间中的用户区数据。但是子进程的内核区的 PCB 没有办法自己释放掉,需要父进程去释放。
  2. 子进程终止时,父进程因为种种原因无法回收,子进程残留资源(PCB)存放于内核中,变成僵尸(Zombie)进程。
  3. 僵尸进程不能被 kill -9 杀死,这样就会导致一个问题,如果父进程不调用 wait() 或 waitpid()的话,那么保留的那段信息就不会释放,其进程号就会一直被占用,但是系统所能使用的进程号是有限的,如果大量的产生僵尸进程,将因为没有可用的进程号而导致系统不能产生新的进程,此即为僵尸进程的危害,应当避免。

解决方法:

通过wait() 和 waitpid() 函数。这两个函数功能一样,区别在于,wait() 函数会阻塞,

waitpid() 可以设置不阻塞,waitpid() 还可以指定等待哪个子进程结束。

注意:一次wait或waitpid调用只能清理一个子进程,清理多个子进程应使用循环。

相关推荐
峰顶听歌的鲸鱼3 小时前
Kubernetes介绍和部署
运维·笔记·云原生·容器·kubernetes·学习方法
物理与数学3 小时前
linux 内存分布
linux·linux内核
信创天地3 小时前
自动化运维利器赋能信创:Ansible与SaltStack在国产系统的部署与批量管理实战
运维·自动化·ansible
东城绝神4 小时前
《Linux运维总结:基于ARM64+X86_64架构使用docker-compose一键离线部署MySQL8.0.43 NDB Cluster容器版集群》
linux·运维·mysql·架构·高可用·ndb cluster
creator_Li4 小时前
即时通讯项目--(1)环境搭建
linux·运维·ubuntu
Ka1Yan4 小时前
Docker:基本概念与快速入门
运维·docker·容器
Mr'liu5 小时前
MongoDB 7.0 副本集高可用部署
linux·mongodb
文静小土豆6 小时前
Rocky Linux 二进制 安装K8S-1.35.0高可用集群
linux·运维·kubernetes
小技工丨6 小时前
华为TaiShan 200 2280 ARM服务器虚拟化部署完整指南
运维·服务器·arm开发
暮云星影6 小时前
二、linux系统 应用开发:整体Pipeline流程
linux·arm开发