在Linux中,如何在自己的进程组中启动进程?和更多

前端之家收集整理的这篇文章主要介绍了在Linux中,如何在自己的进程组中启动进程?和更多前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我想在自己的进程组中启动一个进程(或者,一旦启动就更改其组)并且:

>让组中的进程响应来自终端的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/bash
4759   4759  |       \_ ps fax -o pid,cmd
4760   4759  |       \_ less

请注意,shell已为管道创建了一个新的进程组,并且管道中的每个进程都共享进程组.

编辑:

我想我知道你在做什么.你是从Perl调用系统.显然,sh -c不会创建新的进程组,因为它是一个没有作业控制的shell.

我会做的是分叉,然后是孩子:

setpgrp;
system("ps fax -o pid,cmd");

并等待父母.

猜你在找的Linux相关文章