zoukankan      html  css  js  c++  java
  • shell命令管道未读完阻塞了子进程,与等待其结束的父进程死"锁"。

    在exec执行一个子进程,我们希望使用管道取得子进程在重定向后的标准输出上的结果,同时等待子进程的结束。那么是等待子进程结束后才取管道数据,还是边取数据边等待子进程结束呢?

    这里有一个调试的例子。u0_a89是例子中app的用户id。

    android app 进程 5990,exec了一个sh子进程 6251,去执行命令子进程。

       

    可以查看到app进程由zygote创建,app进程创建了6251,6251创建了6252,并且app进程及其子进程都阻塞去睡眠了。原本6252子进程执行着一个不要阻塞并且十分短小的任务,一瞬就应该完成并结束的。但却无端阻塞走去睡眠了。而sh子进程6251又在等待进程2652结束,app进程也在等待sh子进程结束,这就僵直了。

    原因是app没有分配足够空间去取出管道中的数据,使得 read( pipe, buf, space /** 0 */) 返回 0,再加上epoll为ET触发,然后就没有去读管道了。管道堵满了数据,子进程不能完成数据的传输也被阻塞了。

    一般来说,如果子进程执行的任务只有少量结果输出,不会塞满管道,即使你来不及去读出管道的数据,子进程也已经将结果都填进管道了,也就关闭管道写端,顺利结束。这种情况下,不论你是先读管道,抑或先等待子进程结束也者没有问题。但是当子进程任务输出大量结果数据时,情况就不一样了,你必须及时去读管道,让子进程可以去写管道。如果读的操作不注意,就会出现上面的错误,即使同时也在reactor上等待进程的结束事件,却永远都等不到那一刻了,因为互相死锁了。

  • 相关阅读:
    java web 开发入门
    程序优质网站
    为什么要放弃ssh框架
    JDK核心源码(2)
    Linux 格式化分区 报错Could not stat --- No such file or directory 和 partprobe 命令
    快照COW
    磁盘检测SMART工具
    python学习-3.一些常用模块用法
    python 学习2:生成器,迭代器,装饰器
    关于对SwfUpload的改造
  • 原文地址:https://www.cnblogs.com/bbqzsl/p/7762199.html
Copyright © 2011-2022 走看看