>让组中的进程响应来自终端的Ctrl C.
>获取进程组的ID,以便我可以通过kill命令终止组中的所有进程.
注意:我尝试过setsID prog [args]但是进程没有响应来自终端的Ctrl C,也没有得到新的进程组ID.
我还尝试通过Perl的setpgrp($pID,$pID)和POSIX :: setpgID($pID,$pID)更改进程组,但无济于事.
编辑:更大的问题:
我有一个进程(单线程;让我们称之为“多产”进程P)同步启动许多子进程(一个接一个;当前一个子进程终止时它启动一个新进程).从终端,我希望能够杀死P和它下面的进程树.为此,我可以简单地安排杀死P组中的进程.但是,默认行为是P在其父进程的组中.这意味着如果我杀死P组中的所有进程,P的父级将被杀死,除非我有P并且它的树在他们自己的组中.
我的意图是杀死P和它下面的树,但不是P的父.另外,我无法修改P代码本身.
解决方法 你是什么意思“在自己的过程组中启动一个过程”? shell在它们自己的进程组中启动进程,这就是它如何进行作业控制(通过在前台创建进程的进程组,在后台启动每个进程的几个进程组).要查看shell为每个管道启动新进程组,您可以执行以下 *** 作:
ps fax -o pID,pgID,cmd | less
这将显示如下:
11816 11816 | \_ /bin/bash4759 4759 | \_ ps fax -o pID,cmd4760 4759 | \_ less
请注意,shell已为管道创建了一个新的进程组,并且管道中的每个进程都共享进程组.
编辑:
我想我知道你在做什么.你是从Perl调用系统.显然,sh -c不会创建新的进程组,因为它是一个没有作业控制的shell.
我会做的是分叉,然后是孩子:
setpgrp;system("ps fax -o pID,cmd");
并等待父母.
总结以上是内存溢出为你收集整理的在Linux中,如何在自己的进程组中启动进程?和更多全部内容,希望文章能够帮你解决在Linux中,如何在自己的进程组中启动进程?和更多所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)