首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

僵尸进程与孤立进程

僵尸进程与孤立进程基础概念

僵尸进程(Zombie Process): 僵尸进程是指已经终止,但仍然保留在进程表中的进程。当一个子进程结束运行时,它的进程描述符仍然保留在系统中,直到父进程通过调用 wait()waitpid() 函数来回收它。如果父进程没有及时回收子进程,子进程就会变成僵尸进程。

孤立进程(Orphan Process): 孤立进程是指其父进程已经终止,但子进程仍在运行的进程。当父进程终止时,操作系统会自动将子进程的父进程设置为 init 进程(进程ID为1)。这样,init 进程会负责回收这些孤立进程的资源。

优势与类型

僵尸进程的优势

  • 僵尸进程的存在使得父进程可以获取子进程的退出状态等信息。

孤立进程的优势

  • 孤立进程不会因为父进程的终止而受到影响,可以继续执行任务。

类型

  • 僵尸进程和孤立进程都是进程状态的一种,属于进程管理的一部分。

应用场景

僵尸进程的应用场景

  • 在某些情况下,父进程需要知道子进程的退出状态,因此会保留僵尸进程直到获取这些信息。

孤立进程的应用场景

  • 在守护进程(daemon)的创建过程中,通常会将子进程的父进程设置为 init 进程,以确保子进程能够正常运行。

遇到的问题及解决方法

僵尸进程问题

  • 问题:过多的僵尸进程会占用进程表资源,导致系统性能下降。
  • 原因:父进程没有及时回收子进程。
  • 解决方法
    • 父进程应该调用 wait()waitpid() 函数来回收子进程。
    • 如果父进程无法回收子进程,可以考虑杀死父进程,让 init 进程来回收。
代码语言:txt
复制
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/wait.h>

int main() {
    pid_t pid = fork();
    if (pid == 0) {
        // 子进程
        exit(0);
    } else if (pid > 0) {
        // 父进程
        wait(NULL); // 回收子进程
    } else {
        perror("fork");
        exit(1);
    }
    return 0;
}

孤立进程问题

  • 问题:孤立进程可能会因为没有适当的父进程管理而导致资源泄漏。
  • 原因:父进程意外终止。
  • 解决方法
    • 确保父进程在终止前回收子进程。
    • 使用 init 进程作为默认父进程,通过设置 SIGHUP 信号处理程序来处理父进程终止的情况。
代码语言:txt
复制
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <signal.h>

void sig_hup(int signo) {
    printf("Parent process terminated, cleaning up...\n");
    exit(0);
}

int main() {
    signal(SIGHUP, sig_hup); // 设置 SIGHUP 信号处理程序
    pid_t pid = fork();
    if (pid == 0) {
        // 子进程
        while (1) {
            sleep(1);
        }
    } else if (pid > 0) {
        // 父进程
        exit(0);
    } else {
        perror("fork");
        exit(1);
    }
    return 0;
}

参考链接

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

守护进程僵尸进程

这个树状关系也比较健壮,当某个进程还在运行时,它的父进程却退出了,这个进程却没有成为孤儿进程,因为linux有一个机制,init进程会接管它,成为它的父进程。...这也是守护进程的由来了,因为守护进程的其中一个要求就是希望init成为守护进程的父进程。...进程在退出时执行sys_exit(C程序里在main函数返回会执行到),而它会调用do_exit,do_exit首先清理进程使用的资源,然后调用exit_notify方法,将进程置为僵尸ZOMBIE状态...父进程先fork出一个儿子进程,儿子进程再fork出孙子进程做为守护进程,然后儿子进程立刻退出,守护进程被init进程接管,这样无论父进程做什么事,无论怎么被阻塞,都与守护进程无关了。...所以,fork两次的守护进程很安全,避免了僵尸进程出现的可能性。

1.6K10

僵尸进程孤儿进程

这样设计的目的主要是保证只要父进程想知道子进程结束时的状态信息,就可以得到 僵尸进程: 一个进程使用 fork 创建子进程,如果子进程退出,而父进程并没有调用 wait 或 waitpid 获取子进程的状态信息...,将因为没有可用的进程号而导致系统不能产生新的进程,此即为僵尸进程的危害。...wait 进行处理僵尸进程。...(3)方案三:fork两次: 原理是将进程成为孤儿进程,从而其的父进程变为 init 进程,通过 init 进程处理僵尸进程。...于是父进程孙子进程无继承关系了,它们的父进程均为Init,Init进程在其子进程结束时会自动收尸,这样也就不会产生僵死进程了 (4)方案四:kill 父进程: 严格地来说,僵死进程并不是问题的根源,罪魁祸首是产生出大量僵死进程的那个父进程

28050
  • 详解僵尸进程孤儿进程

    什么是僵尸进程孤儿进程 在 linux 系统中,进程都是由父进程创建的,当父进程执行 fork 系统调用完成子进程创建后,子进程和父进程就独立存在了,但两者又有着密切的关系,按照标准的流程,父进程要在子进程完成执行后...但这个过程存在两个问题,那就是如果父进程先于子进程退出了怎么办?以及子进程退出以后,父进程始终没有调用 wait 或 waitpid 怎么办?这就产生了两种进程:孤儿进程僵尸进程。...怎么避免僵尸进程 既然僵尸进程是我们不希望看到的,那么如何避免产生僵尸进程呢?...\n"); exit(-1); } exit(0); } 5. docker 中如何避免僵尸进程 5.1 docker 中的僵尸进程 Docker...这也就意味着,在我们的 docker 中,如果某一层的进程退出,那么他的所有子孙进程在结束后都会变成僵尸进程。 5.2 守护进程 如何解决这个问题呢?

    1.9K20

    僵尸进程

    1.什么是僵尸进程?     UNIX 系统中,一个进程结束了,但是他的父进程没有等待(调用wait / waitpid)他,而父进程还没有结束,那么他将变成一个僵尸进程.    ...,成为他的父进程,从而保证每个进程都会有一个父进程.而Init进程会自动wait其子进程,因此被Init接管的所有进程都不会变成僵尸进程. 2.子进程结束后为什么要进入僵尸状态?    ...如果父进程能及时 处理,可能用ps命令就来不及看到子进程僵尸状态,但这并不等于子进程不经过僵尸状态。     如果父进程在子进程结束之前退出,则子进程将由init接管。...init将会以父进程的身份对僵尸状态的子进程进行处理。...4.如何查看僵尸进程: $ ps -el     其中,有标记为Z的进程就是僵尸进程     S代表休眠状态;D代表不可中断的休眠状态;R代表运行状态;Z代表僵死状态;T代表停止或跟踪状态 5.僵尸进程的避免

    1.4K50

    Operating System 03 - 孤儿进程僵尸进程

    孤儿进程僵尸进程 孤儿进程 一个父进程退出, 而他的一个或者多个子进程还在运行, 那么这些子进程将成为孤儿进程....僵尸进程 一个子进程进程描述符在子进程退出不会释放, 只有当父进程通过wait()或者waitpid()获取了子进程信息后才会释放....如果子进程退出, 而父进程并没有调用wait()或者waitpid(), 那么子进程描述符仍然保存在系统中, 这种进程称之为僵尸进程. 僵尸进程通过ps命令显示出来的状态为Z(zombie)....系统所能使用的进程号是有限的, 如果产生大量僵尸进程, 将因为没有可用的进程号而导致系统不能产生新的进程....要消灭系统中大量的僵尸进程, 只需要将其父进程杀死, 此时僵尸进程就会变为孤儿进程, 从而被init收养, 这样init就会释放掉所有的僵尸进程所占有的资源, 从而结束僵尸进程.

    53320

    孤儿进程僵尸进程

    linux基础 僵尸进程进程exit()退出之后,他的父进程没有通过wait()系统调用回收他的进程描述符的信息,该进程会继续停留在系统的进程表中,占用内核资源,这样的进程就是僵尸进程。...)); sleep(60); printf("parend finally..."); } } 孤儿进程 当一个进程正在运行时,他的父进程忽然退出,此时该进程就是一个孤儿进程...作为一个进程,需要找到一个父进程,否则这种进程在退出之后没人回收他的进程描述符,空耗内存。此时该进程会找到一个父进程,如果自己所在的进程组没人收养,那就作为init进程的子进程。...finally..."); } } 处置方式 孤儿进程会由init进程收养作为子进程,所以不会有什么危害;僵尸进程会占用进程号,以及未回收的文件描述符占用空间,如果产生大量的僵尸进程,将会导致系统无法分配进程号...$ ps -aux|grep Z 在理想情况下,可以通过kill命令将进程杀死该进程的父进程来结束僵尸进程。当然也要结合具体场景来对待。

    1K10

    孤儿进程僵尸进程

    僵尸进程:一个进程使用fork创建子进程,如果子进程退出,而父进程并没有调用wait或waitpid获取子进程的状态信息,那么子进程进程描述符仍然保存在系统中。这种进程称之为僵死进程。...此即为僵尸进程的危害,应当避免。 孤儿进程是没有父进程进程,孤儿进程这个重任就落到了init进程身上,init进程就好像是一个民政局,专门负责处理孤儿进程的善后工作。...任何一个子进程(init除外)在exit()之后,并非马上就消失掉,而是留下一个称为僵尸进程(Zombie)的数据结构,等待父进程处理。这是每个 子进程在结束时都要经过的阶段。...如果父进程能及时 处理,可能用ps命令就来不及看到子进程僵尸状态,但这并不等于子进程不经过僵尸状态。 如果父进程在子进程结束之前退出,则子进程将由init接管。...init将会以父进程的身份对僵尸状态的子进程进行处理。

    1.7K30

    【Linux系统编程】僵尸进程孤儿进程

    僵尸进程 上一篇文章进程的状态中最后我们提出了僵尸状态: 为了方便子进程退出后父进程或操作系统获取该进程的退出结果,Linux进程退出时,进程一般不会立即死亡,而是要维持一个Z状态即——僵尸状态。...那处在僵尸状态的进程僵尸进程,那首先我们就要来重点理解一下僵尸进程。 那我们来给大家讲一个故事: 假如你呢是一名非常自律上进的大学生,每天早晨都有到外面跑步的好习惯。...僵尸进程会以终止状态保持在进程表中,并且会一直在等待父进程读取退出状态代码。 所以,只要子进程退出,但父进程还在运行,且父进程没有读取子进程退出的返回代码,子进程就会进入僵尸状态。...那按我们上面讲的,子进程退出,父进程还在运行,且没有回收子进程获取返回码(我们现在也不会),那么子进程就会进入僵尸状态 ,那我们现在干掉子进程 然后我们再来查看 子进程就变成了僵尸进程...那以上就是关于僵尸进程和孤儿进程的相关内容…

    25510

    Linux僵尸进程

    僵尸进程太多会导致操作系统的进程数目过多,从而占满了OS的进程表。进而导致无法创建新进程,致使OS崩溃。...僵尸进程几乎不占资源,它没有可执行代码,也不能被调度,但是它占据着进程表中的一个位置,记载这该进程的PCB信息。它需要等待他的父进程来终结它。...在Linux下使用top命令可以产看当前进程数目,以及进程的状态。例如: ? 可以看到我的系统暂时并没有僵尸进程(zombie) 。挂起的进程倒是一大堆。...僵尸进程产生的原因:每个Linux进程进程表中都有一个进入点,内核执行该进程时,使用到的一切信息都存入在进程点。我们可以使用ps命令来查看进程状态。...而当这个子进程结束的时候(调用exit命令结束),其实他并没有真正的被销毁,而是留下一个僵尸进程的。

    4.5K20

    闲聊僵尸进程

    僵尸进程 记得好像写过相关僵尸进程的东西,稍微再写一点,因为总是有人说僵尸进程的存在会导致机器的load值变高,不知道哪里看到的谬论。...,僵尸进程的状态为Z。...从以上来看,僵尸进程的存在并不会导致服务器的load值变高,而且,僵尸进程的存在不会占用内存,不会占用cpu时间,仅仅占用一个进程的数据结构,也就是进程号是占用的,从而最坏的结果就是导致服务器上不能创建新的进程...在使用容器的时候,产生僵尸进程的概率大大增加,为啥呢?...僵尸进程没有想象中的那么可怕,一个服务器上几万个僵尸进程,也就那样,重启下容器就好了。。。重启试试。 重点在于找到僵尸进程产生的程序,然后修改程序,而不是仅仅重启,心情不好,睡一觉就好了?

    1.8K10

    僵尸进程的产生处理

    僵尸进程(Zombie Process)是指在操作系统中已经完成了执行,但其父进程尚未调用wait()或waitpid()来获取其终止状态的子进程。...当一个进程结束时,操作系统会保留该进程的一些基本信息,包括进程ID(PID)、退出状态等,以供父进程查询。...而如果父进程没有主动调用上述函数来检索该进程的状态,那么这个进程的信息就会一直存在于操作系统的进程表中,成为僵尸进程。...如下是一个产生僵尸进程的代码 void fork7() { if (fork() == 0) { /* Child */ printf("Terminating...获取子进程的终止状态:当子进程终止时,操作系统会将子进程的退出状态传递给父进程。父进程通过调用wait()或waitpid()来获取子进程的终止状态,并可以根据该状态进行后续处理。

    28820

    探索Linux下进程状态 | 僵尸进程 | 孤儿进程

    如果没有父进程读取,僵尸进程会一直存在。 上述代码中,子进程执行完五次后,就处于Z状态并且后面跟了一个,该单词有不存在的意思,只不过还等待父进程来回收它的资源。...一般的,我们讲这种处于Z状态的进程叫做僵尸进程,如果父进程一直不回收,将长时间占用内存资源,造成内存泄漏。...僵尸进程危害: 进程的退出状态必须被维持下去,因为他要告诉关心它的进程(父进程),你交给我的任务,我办的怎么样了。可父进程如果一直不读取,那子进程就一直处于Z状态?是的!...,只剩下子进程,为什么父进程不会处于僵尸进程?...父进程也是bash的子进程,父进程结束后,它的父进程bash会将它回收掉,并且过程很快,所以父进程不会处于僵尸状态。

    13710

    僵尸进程的问题

    若父进程在一定的时间内无法收集到状态信息,则系统中就会残留一个僵尸进程。 因为僵尸进程是已经停止的,所以使用杀死进程的方法来杀僵尸进程是无效的。...init进程是系统中所有进程的起源。 通常情况下,init进程通过将僵尸进程的PPID设为1来收回该进程。 如果一个僵尸进程的父进程号为1,则需要确认该僵尸进程是否已结束了若干分钟。...(方法是等几分钟后再查看该僵尸进程是否还存在。) 一个系统中,特别是任务繁忙的系统中,父进程为init的僵尸进程存在1~2分钟是正常的。...如果将此信号的处理方式设为忽略,可让内核把僵尸进程转交给init进程去处理,省去了大量僵尸进程占用系统资源。...signal(SIGCHLD,SIG_IGN); 这样,内核在子进程结束时不会产生僵尸进程。这一点BSD4不同,BSD4下必须显式等待子进程结束才能释放僵尸进程

    2.5K121

    UNIX(进程间通信):03---僵尸进程

    僵尸进程 僵尸进程是指一个已经终止、但是其父进程尚未对其进行善后处理获取终止进程的有关信息的进程,这个进程被称为“僵尸进程”(zombie)。...怎样产生僵尸进程 一个进程在调用exit命令结束自己的生命的时候,其实它并没有真正的被销毁,而是留下一个称为僵尸进程(Zombie)的数据结构(系统调用exit, 它的作用是使进程退出,但也仅仅限于将一个正常的进程变成一个僵尸进程...但是如果如果父进程是一个循环,不会结束,那么子进程就会一直保持僵尸状态,这就是 为什么系统中有时会有很多的僵尸进程。...怎么查看僵尸进程 利用命令ps,可以看到有父进程ID为1的进程是孤儿进程;s(state)状态为Z的是僵尸进程。...父进程死后,僵尸进程成为"孤儿进程",过继给1号进程init,init始终会负责清理僵尸进程,关机或重启后所有僵尸进程都会消失。

    73030

    CC++ 进程隐藏&加载寄生&僵尸进程

    众所周知,windows下可执行文件必须符合一定的格式要求,微软官方称之为PE文件(关于PE文件的详细介绍这里就不赘述了,google一下可以找到大把);用户在界面双击exe时,有个叫做explorer的进程会监测并接受到这个事件...然后根据注册表中的信息取得文件名,再以Explorer.exe这个文件名调用CreateProcess函数去运行用户双击的exe;PC中用户一般都是这样运行exe的,所以很多用户态的exe都是exlporer的子进程...分配内存   既然是运行,肯定是需要放在内存的,所以首先要开辟内存空间,才能把exe从磁盘加载进来;以32位为例,由于每个进程都有自己的4GB虚拟空间,所以还涉及到新生成页表、填充CR3等琐碎的细节工作...//将内存中的exe数据映射到peloader进程内存中,避免重新生成一个进程,这是隐藏exe的方式之一 if (FALSE == MapFile(pFileBuff, chBaseAddress...,然后运行exe的,所以exe的代码和数据其实都在loader的空间,并未单独生成一个进程,所以任务管理器、process hacker是都查不到的!

    81620
    领券