我想在自己的进程组中启动一个进程(或者,一旦启动就更改其组),并:
Ctrl
+ C
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/bash
4759 4759 | \_ ps fax -o pid,pgid,cmd
4760 4759 | \_ less
请注意, shell 程序已为管道创建了一个新的进程组,并且管道中的每个进程都共享该进程组。
编辑:
我想我知道你在做什么。您正在从Perl调用
system
。显然,sh -c
不会创建新的进程组,因为它是一个没有作业控制的 shell 。我要做的就是
fork
,然后在 child 身上:setpgrp;
system("ps fax -o pid,pgid,cmd");
以及父项上的
wait
。关于linux - 如何在自己的流程组中启动流程?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/5809034/