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

Linux】深入 Linux 进程等待机制:阻塞与非阻塞的奥秘

为什么需要进行进程等待 进程等待是多进程编程中至关重要的一部分,主要原因是为了让父进程正确管理子进程生命周期并避免各种问题。...避免僵尸进程,虽然子进程已经结束运行,但是它在进程中仍然回保留占位条目,需要父进程回收。 获取子进程的退出状态,用来判断子进程是否成功执行完成任务 2....如果子进程已经退出,调用wait/waitpid会立即返回,并且释放资源,获取子进程退出信息。 如果任意时刻调用wait/waitpid,子进程存在且正常运行,则可能阻塞。...3.解释堵塞与非堵塞 阻塞场景:打电话等朋友接听 你拨打朋友的电话,直到朋友接通之前你什么都做不了。这就像阻塞调用,你必须等着事情完成。...非阻塞场景:发消息等待回复 你给朋友发了个消息,等他们回你。你不用一直盯着手机看,而是可以去做别的事情,等收到消息后再查看。这就像非阻塞调用,你不需要等着完成才能做其他事情。

9310

Linux进程状态&&僵尸进程和孤儿进程&&阻塞、挂起和运行

前言 上一篇博客中提到 【Linux进程初步理解,这次继续来分享与进程有关的知识。 2. Linux进程状态 Linux进程状态就是struct task_struct内部的一个属性。...为了弄明白正在运行的进程是什么意思,我们需要知道进程的不同状态。一个进程可以有几个状态(在Linux内核里,进程有时候也叫做任务)。...让进程自己醒来;2. 重启–断点 3. 僵尸进程和孤儿进程 3.1 僵尸进程 Linux中一个进程的退出,它会将自己的退出信息保留在自己的PCB中。...因为直接在命令行中启动的进程,它的父进程是bash,bash会自动回收新进程的Z。 4. 进程阻塞、挂起和运行 在网上找的一张进程状态图: 终止状态就等价于Z状态和X状态。...阻塞和运行的状态变化,往往伴随进程PCB被连入到不同的队列中。

42710
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Linux进程信号【信号处理

    信号没有被阻塞,直接产生,记录未决信息后,再进行处理 在这种情况下,信号是不会被立即递达的,也就无法立即处理,需要等待合适的时机 特殊情况 当信号被 阻塞 后,信号 产生 时,记录未决信息,此时信号被阻塞了...,也不会进行处理阻塞解除后,信号会被立即递达,此时信号会被立即处理 特殊情况 很好理解,就好比往气球里吹气,当气球炸了,空气会被立即释放,因为空气是被气球 阻塞 的,当气球炸了之后(阻塞 解除),空气立马往外跑...检测 并 处理 了 情况1:信号被阻塞,信号产生/未产生 信号都被阻塞了,也就不需要处理信号,此时不用管,直接切回 用户态 就行了 下面的情况都是基于 信号未被阻塞 且 信号已产生 的前提 情况...,还需要坠入 内核态 通过一张图快速记录信号的 处理 过程 图片来源:Linux进程信号 ---- 3、信号的捕捉 接下来谈谈 信号 是如何被 捕捉 的 3.1、内核如何实现信号的捕捉?...:信号在 内核态 切换回 用户态 时,才会被处理 ---- 总结 以上就是本次关于 Linux进程信号【信号处理】的全部内容了,本文对信号的处理时机做了探讨,然后学习了 用户态 和 内核态 的相关内容

    24910

    Linux】解析在【进程PCB】中是如何实现【信号的处理方式(抵达未决阻塞)】

    信号从产生到递达 之间 的状态 信号阻塞 (Block):进程可以选择阻塞 (Block )某个信号。...注意: 被阻塞 的信号产生时将 保持在未决状态 ,直到进程解除对此信号的阻塞,才执行递达的动作....注意,阻塞和忽略是不同的,只要信号被阻塞就不会递达,而忽略是在递达之后可选的一种处理动作 二.信号处理动作在内核中的表示 1.示意图&作用机制介绍&信号集sigeset_t介绍...每个进程PCB中 都有如下图所示三张表,分别叫做 阻塞信号集,未决信号集,处理动作集 ,对应各个信号(1-64) block&pending&handler表 ,分别表示 阻塞(block)和 未决...block位图为1;阻塞状态解除后设置成0; 2.演示在三张表中的表示 演示: 3.如何改变信号的默认实现动作 【1】实现原理:设置信号的【默认处理函数】变成【自定义函数】 每个进程

    12710

    php 多进程编程父进程阻塞与非阻塞实例分析

    本文实例讲述了php 多进程编程父进程阻塞与非阻塞。分享给大家供大家参考,具体如下: php中进程阻塞,主要是父进程等待子进程退出。 1.php代码如下: <?...,也就是主进程 //我们的for循环第一次进入到这里时,pcntl_wait会挂起当前主进程,等待第一个子进程执行完毕退出 //注意for循环的代码是在主进程的,挂起主进程,相当于当前的...for循环也阻塞在这里了 //第一个子进程退出后,然后再创建第二个子进程,到这里后又挂起,等待第二个子进程退出,继续创建第三个,等等。。...sleep(3); exit; } } //我们把pcntl_waitpid放到for循环外面,那样在for循环里创建子进程就不会阻塞了 //但是在这里仍会阻塞,主进程要等待5个子进程都退出后...代码3.php与2.php效果一样,pcntl_wait()函数的作用只是用来让父进程等待子进程退出,默认情况下会阻塞进程

    89341

    Linux系统编程-进程概念、进程管理、信号处理

    文本区域存储处理器执行的代码;数据区存储变量和动态分配的内存;堆栈区存储着活动进程调用的指令和本地变量。 第二,进程是一个“执行中的程序”,它和程序有本质区别。...程序是静态的,它是一些保存在磁盘上的指令的有序集合;而进程是一个动态的概念,它是一个运行着的程序,包含了进程的动态创建、调度和消亡的过程,是Linux的基本调度单位。...只有当处理器赋予程序生命时,它才能成为一个活动的实体,称之为进程Linux在命令行上可以用ps命令查看后台运行的进程详细信息。 2....查看可执行文件的内部空间布局 进程是动态的(内存里的)、程序是静态的_a.out(硬盘上)。 Linux进程都是运行在虚拟地址空间的—MMU。每个进程的空间是独立的(物理地址)。...进程前台与后台切换方式 [wbyq@wbyq linux_c]$ .

    99620

    2.中断和进程阻塞

    本篇是多路复用相关的知识的第二篇文章,主要讲解中断和进程阻塞在整个网络数据传递过程中,所经历的过程。...然后,网卡向cpu发出一个中断信号,操作系统便能得知有新数据到来,再通过网卡中断程序去处理数据。...二、进程阻塞 阻塞进程调度的关键一环,指的是进程在等待某事件(如接收到网络数据)发生之前的等待状态,recv、select和epoll都是阻塞方法。 对于阻塞来说,是不占用CPU资源的。...下面我们看下“进程阻塞为什么不占用cpu资源?” 操作系统为了支持多任务,实现了进程调度的功能,会把进程分为“运行”和“等待”等几种状态。...由于工作队列只剩下了进程B和C,依据进程调度,cpu会轮流执行这两个进程的程序,不会执行进程A的程序。 所以进程A被阻塞,不会往下执行代码,也不会占用cpu资源。 ?

    1.7K31

    Linux编程(阻塞和非阻塞IO)

    Linux设备驱动中的阻塞和非阻塞I/0,简单来说就是对I/O操作的两种不同的方式,驱动程序可以灵活的支持用户空间对设备的这两种访问方式。...一、基本概念: 阻塞操作:是指在执行设备操作时,若不能获得资源,则挂起进程直到满足操作条件后再进行操作。被挂起的进程进入休眠, 被从调度器移走,直到条件满足。...,没有输入则进程挂起睡眠 if(res == 1) { printf("%c/n",buf); } 非阻塞地读一个字符: char buf; fd = open("/dev/ttyS1",O_RDWR...return mask; } 三、总结 阻塞与非阻塞操作: 定义并初始化等待对列头; 定义并初始化等待队列; 把等待队列添加到等待队列头 设置进程状态(TASK_INTERRUPTIBLE(可以被信号打断...)和TASK_UNINTERRUPTIBLE(不能被信号打断)) 调用其它进程

    5.5K20

    linux阻塞与非阻塞(connect连接超时)

    阻塞connect详情介绍可以参见文章:https://blog.csdn.net/qq_41453285/article/details/89890429 一、非阻塞connect概述 man手册...只是当前连接还没有建立完整),所以我们可以在通过给select、pol或epoll设置等待时间,来等待这个connect的连接成功,从而进一步处理 如果非阻塞connect返回的错误不是EINPROGRESS...,代表就是connect系统调用本身出错了,那么就可以做一些相应的错误处理了 ③当非阻塞connect以EINPROGRESS错误返回之后,我们可以给select、pol或epoll设置等待时间,并将客户端封装在等待可写的结构中...,进一步来等待非阻塞connect客户端与服务端建立完整地连接,在等待的过程中,如果非阻塞connect建立成功了,客户端的sock_fd就会变成可写的(这个在本人的IO复用文章中介绍过,见下图) ④当非阻塞...在有些系统(比如Linux)上返回-1,而在有些系统上(比如源自伯克利的UNIX)返回0 这些问题没有一个统一的解决办法 三、编码演示案例 #include #include <stdlib.h

    6.4K10

    php多进程中的阻塞与非阻塞操作实例分析

    本文实例讲述了php多进程中的阻塞与非阻塞操作。分享给大家供大家参考,具体如下: 我们通过pcntl_fork来创建子进程,使用pcntl_wait和pcntl_waitpid来回收子进程。...子进程退出后,父进程没有及时回收,就会产生僵尸进程。 例1: <?...,父进程阻塞着等待子进程退出,然后创建下一个子进程。...上述代码输出结果如下: 20081 0 20082 1 20083 2 20084 3 20085 4 但我们创建多进程的目的,就是为了能够并行的处理任务,阻塞的方式并不是我们想看到的。 例2: <?...WNOHANG); } else { echo getmypid() , " {$i} rn"; exit; } } 我们可以通过设置pcntl_wait的第二个参数为WNOHANG来控制进程是否阻塞

    67900

    linux下僵尸进程的发现与处理

    一、概述 僵尸进程是怎么产生的 当子进程退出时,父进程没有调用wait函数或者waitpid()函数等待子进程结束,又没有显式忽略SIGCHLD信号,那么它将一直保持在僵尸状态,如果这时父进程结束了,init...进程会自动接收这个子进程,为它收尸,但如果父进程是一个循环,不会结束,那么子进程就会一直保持僵死状态。...参数列出所有进程 -o 自定义输出字段 我们设定显示字段为 stat(状态), ppid(进程父id), pid(进程id),cmd(命令)这四个参数 因为状态为 z或者Z 的进程为僵尸进程,所以我们使用...Z    14:06   0:00 [check_haproxy.s]  三、杀死僵尸进程 一台服务器上产生了100多少僵死进程,而且每一僵死进程的父进程都不一样,如果用  kill ...-9 进程id 一条一条的杀,那还不得累死我啊。

    1.8K32

    L010Linux和androidNDK之linux避免僵尸进程,子进程退出的处理

    L010Linux和androidNDK之linux避免僵尸进程,子进程退出的处理 如果你在程序中fork出一个子进程,没有好好处理进程退出后的相关事宜,那么就有可能召唤出传说中进程界的僵尸---僵尸进程...,并不能将其完全销毁) 僵尸进程是怎么样产生 在Linux进程的状态中,僵尸进程是非常特殊的一种,它已经放弃了几乎所有内存空间,没有任何可执行代码,也不能被调度,仅仅在进程列表中保留一个位置,记载该进程的退出状态等信息供其他进程收集...如果他的父进程没安装SIGCHLD信号处理函数调用wait或waitpid()等待子进程结束,又没有显式忽略该信号,那么它就一直保持僵尸状态,如果这时父进程结束了,那么init进程自动会接手这个子进程,...异步回收僵尸进程: fork()之后,子进程从父进程获取了一份拷贝,和父进程分别独立运行,僵尸进程的产生是因为父进程没有给子进程“收尸”造成的,又可以根据危害程度分为下述两类: 总体来说:当子进程结束之后...(1)当子进程结束之后,但父进程未结束之前,子进程将成为僵尸进程,父进程结束后僵尸被init进程回收。

    3.1K40

    Linux进程优先级的处理--Linux进程的管理与调度(二十二)

    1. linux优先级的表示 1.1 优先级的内核表示 linux优先级概述 在用户空间通过nice命令设置进程的静态优先级, 这在内部会调用nice系统调用, 进程的nice值在-20~+19之间....从0~99的范围专供实时进程使用, nice的值[-20,19]则映射到范围100~139 linux2.6内核将任务优先级进行了一个划分, 实时优先级范围是0到MAX_RT_PRIO-1(即99),...优先级范围 描述 0——99 实时进程 100——139 非实时进程 内核的优先级表示 内核表示优先级的所有信息基本都放在include/linux/sched/prio.h中, 其中定义了一些表示优先级的宏和函数...include/linux/sched/deadline.h #define MAX_DL_PRIO 0 此外也提供了一些EDF优先级处理所需的函数, 如下所示, 可以参见内核文件...- 概述(一) 深入 Linux进程优先级

    3.6K61

    阻塞队列的核心方法&对阻塞的不同处理

    阻塞队列,顾名思义,首先它是一个队列,而一个阻塞队列在数据结构中所起的作用大致如下图所示: 阻塞队列 当阻塞队列是空时,从队列中获取元素的操作将会被阻塞。...当阻塞队列是满时,往队列里添加元素的操作将会被阻塞。 试图从空的阻塞队列中获取元素的线程将会被阻塞,直到其他的线程往空的队列插入新的元素。...同样 试图往己满的阻塞队列中添加新元素的线程同样也会被阻塞,直到其他的线程从列中移除一个或者多个元素或者完全清空队列后使队列重新变得空闲起来并后续新增 在多线程领域:所谓阻塞,在某些情况下会起线程(即阻塞...BlockingQueue是隶属于Collection下的BlockingQueue接口,于list,set平级) BlockingQueue核心方法 三种类型的方法,针对非法添加或者得到队列元素做的处理方式不同又分为四组...不同组对阻塞进行了不同的处理 关于SynchonousQueue同步队列 SynchronousQueue没有容量。

    68920

    Linux shell 多进程和文件队列处理任务

    拉取的文件未压缩,导致网络流量浪费 任务都混杂在一个文件中,不清晰 如果任务的执行时间超过1天,会对定时任务造成影响 想到的解决方法 将串行任务执行改成并行任务执行 任务分解到不同的文件中,用专门的处理进程处理...先压缩后拉取,然后删除掉应用服务器上的压缩文件 前期准备 由于对shell以前只是停留在偶尔用的程度,许多知识都需要现查,因此又去学习了一遍,其中包括shell中多进程任务执行,文件监听处理,以及常用的...Linux命令 Linux多任务执行 (多任务执行|http://www.cnblogs.com/xudong-bupt/p/6079849.html) (多进程并发|http://www.cnblogs.com...文件监听处理 以前用kafka做日志处理时,记得有一个可以使用tail来创建生产者,因此朝着这方面找了下资料,确实可以这么做 shell function dosth(){} tail -f -n 100...& done 其他 Linux函数调用,scp,gzip,echo等命令看了下他们的man页,做起来更有信心 动手 任务分类 目前有两个任务,一是拉取日志,二是删除过期日志,因此使用两个文件队列来分别表示这两个任务

    2K30

    Linux进程——Linux进程进程优先级

    如果对前面Linux进程不太熟悉可以先阅读: Linux进程 本篇主要内容: 僵尸进程和孤儿进程 Linux进程优先级 1. 僵尸进程 僵尸进程就是处于僵尸状态下的进程!...配置进程优先权对多任务环境的linux很有用,可以改善系统性能。...NI :NICE值,表示优先级的修改数据 NICE其取值范围是-20至19,一共40个级别 Linux进程的优先级数值范围:60~99 Linux中默认进程的优先级都是:80 Linux是支持动态优先级调整的...因为: PRI(新) = PRI(old) + NICE 注意:PRI(old)在修改时,同意按80处理!...总结 本篇文章前部分紧贴上篇Linux进程,分析完了Linux下常见的进程状态,然后初步了解了Linux进程优先级,而进程优先级与前面内容相差较大,希望大家能够多花点时间理解!

    10210

    LinuxLinux进程控制>进程创建&&进程终止&&进程等待&&进程程序替换

    1.进程创建 1.1 fork函数 在linux中fork函数时非常重要的函数,它从已存在进程中创建一个新进程。...具体见下图: 1.3 fork常规用法 一个父进程希望复制自己,使父子进程同时执行不同的代码段。例如,父进程等待客户端请求,生成子进程处理请求 一个进程要执行一个不同的程序。...如果子进程已经退出,调用wait/waitpid时,wait/waitpid会立即返回,并且释放资源,获得子进程退出信息 如果在任意时刻调用wait/waitpid,子进程存在且正常运行,则进程可能阻塞.../a.out #等20秒退出 child exit code:10 [root@localhost linux]# ..../a.out #在其他终端kill掉 sig code : 9 3.2.4 进程阻塞等待方式 int main() { pid_t pid; pid = fork(); if (pid < 0)

    15410
    领券