免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123下一页
最近访问板块 发新帖
查看: 11397 | 回复: 22
打印 上一主题 下一主题

执行system后产生defunct,高手进来分析下 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-07-22 15:53 |只看该作者 |正序浏览
程序中通过system()调用另一个可执行程序, 如:
if (0 != system("./exe_process args"))
{
     DEBUGLOG("error");
}

但在长期运行中经常发现出现 exe_process 的defunct进程, 看了下system的源码, 无非就是fork, exec, waitpid

不明白为什么会出现僵尸进程

补充: 此程序运行时内存可能有限, 不知道是否有影响

论坛徽章:
0
23 [报告]
发表于 2010-07-25 19:54 |只看该作者
子进程退出的状态无法回收资源,这样的进程就叫僵尸进程,也KILL不掉

论坛徽章:
0
22 [报告]
发表于 2010-07-25 11:33 |只看该作者
system()一般是通过“sh -c”来执行程序的,有可能sh异常退出,或者你的主程序里有fork(),子进程执行的快,把system()里的waitpid()给中断了?

论坛徽章:
0
21 [报告]
发表于 2010-07-25 08:54 |只看该作者
一般都不会产生僵尸进程吧,因为init进程一直在守护等待它

论坛徽章:
0
20 [报告]
发表于 2010-07-24 15:14 |只看该作者
是不是你这个父进程了sleep 语句或 wait语句呢???

论坛徽章:
84
每日论坛发贴之星
日期:2015-12-29 06:20:00每日论坛发贴之星
日期:2016-01-16 06:20:00每周论坛发贴之星
日期:2016-01-17 22:22:00程序设计版块每日发帖之星
日期:2016-01-20 06:20:00每日论坛发贴之星
日期:2016-01-20 06:20:00程序设计版块每日发帖之星
日期:2016-01-21 06:20:00每日论坛发贴之星
日期:2016-01-21 06:20:00程序设计版块每日发帖之星
日期:2016-01-23 06:20:00程序设计版块每日发帖之星
日期:2016-01-31 06:20:00数据库技术版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-14 06:20:00
19 [报告]
发表于 2010-07-23 23:05 |只看该作者
程序中通过system()调用另一个可执行程序, 如:
if (0 != system("./exe_process args")
{
     DE ...
morris2600 发表于 2010-07-22 15:53


忘了问了,你的exe_process程序本身里面有没有fork之类的动作,这也是要考虑的一个问题,,

论坛徽章:
84
每日论坛发贴之星
日期:2015-12-29 06:20:00每日论坛发贴之星
日期:2016-01-16 06:20:00每周论坛发贴之星
日期:2016-01-17 22:22:00程序设计版块每日发帖之星
日期:2016-01-20 06:20:00每日论坛发贴之星
日期:2016-01-20 06:20:00程序设计版块每日发帖之星
日期:2016-01-21 06:20:00每日论坛发贴之星
日期:2016-01-21 06:20:00程序设计版块每日发帖之星
日期:2016-01-23 06:20:00程序设计版块每日发帖之星
日期:2016-01-31 06:20:00数据库技术版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-14 06:20:00
18 [报告]
发表于 2010-07-23 16:13 |只看该作者
system 执行的程序的直接父进程是shell进程,看看这个shell的类型、版本吧,,

论坛徽章:
84
每日论坛发贴之星
日期:2015-12-29 06:20:00每日论坛发贴之星
日期:2016-01-16 06:20:00每周论坛发贴之星
日期:2016-01-17 22:22:00程序设计版块每日发帖之星
日期:2016-01-20 06:20:00每日论坛发贴之星
日期:2016-01-20 06:20:00程序设计版块每日发帖之星
日期:2016-01-21 06:20:00每日论坛发贴之星
日期:2016-01-21 06:20:00程序设计版块每日发帖之星
日期:2016-01-23 06:20:00程序设计版块每日发帖之星
日期:2016-01-31 06:20:00数据库技术版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-14 06:20:00
17 [报告]
发表于 2010-07-23 15:53 |只看该作者
以前碰到过一个bash的bug,特定情况下bash core掉了;

system 默认是启动一个默认 shell 来解释执行命令,难道,,   纯属猜测你还是google吧

good luck

论坛徽章:
84
每日论坛发贴之星
日期:2015-12-29 06:20:00每日论坛发贴之星
日期:2016-01-16 06:20:00每周论坛发贴之星
日期:2016-01-17 22:22:00程序设计版块每日发帖之星
日期:2016-01-20 06:20:00每日论坛发贴之星
日期:2016-01-20 06:20:00程序设计版块每日发帖之星
日期:2016-01-21 06:20:00每日论坛发贴之星
日期:2016-01-21 06:20:00程序设计版块每日发帖之星
日期:2016-01-23 06:20:00程序设计版块每日发帖之星
日期:2016-01-31 06:20:00数据库技术版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-14 06:20:00
16 [报告]
发表于 2010-07-23 15:50 |只看该作者
感谢关注

所谓僵尸进程,应该是子进程退出了, 而父进程并没有处理子进程的退出(waitpid或SIGCHLD等), ...
morris2600 发表于 2010-07-22 20:25



哦,明白你的问题了; 以前用过system() 但没碰到过这种问题。

什么环境? 建议 google system bug 看看吧,

论坛徽章:
0
15 [报告]
发表于 2010-07-23 10:37 |只看该作者
回复  duanjigang


    谢谢你详细的例子

   可能是我没说清楚, 或者没有把重点突出出来,

   ...
morris2600 发表于 2010-07-23 10:36



    喔,呵呵,那就看看你的system执行的程序了,理解又偏差了{:3_183:}
  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP