如何识别子进程的子进程

How can one identify children of a child process?

本文关键字:子进程 识别 何识别      更新时间:2023-10-16

我有一个长期运行的Python程序,作为其操作的一部分,它启动和停止Postgres服务器。我使用子进程生成pg_ctl -m fast来停止服务器。作为后备,我检查返回代码,如果失败,则运行pg_ctl -m immediate

问题是有时两者都会失败。我自己还没能重现这一点,但对于我的程序的用户来说,这种情况会发生一些频率。我从pg_ctl调用中记录stdout/stderr,但没有得到任何有用的信息。据我所知,主进程或其子进程已经停止响应SIGQUIT,终止它们的唯一方法是使用SIGKILL,pg_ctl不使用它。

我基本上已经用尽了Postgres方面的想法。我使用的是Postgres8.3,所以我相信升级到更新的版本会解决这个问题,但不幸的是,这不是我的选择。我唯一能想到的解决方案是手动杀死孩子。但我不知道如何区分由我的pg_ctl start和可能在机器上运行的其他postgres进程生成的子进程。

有没有一种方法可以将一个进程识别为我所生成的另一个进程的子进程?从Python实现这一点的跨平台方法是理想的,但如果Windows/Linux/UNIX上有API,我愿意编写一个C扩展。

这里有一个简单的shell脚本解决方案:

pgrep -P $(head -1 $PGDATA/postmaster.pid)

这将打印出子进程的PID。

我不知道有什么标准的Python模块可以获得这些信息。pgrep/proc获得信息,所以您可以在Python中重新实现它,但我怀疑这是否值得。

C++标准不知道多进程系统。因此,没有API用于与流程交互。(毕竟,标准如何在8位微控制器上强制要求多处理系统?)

此外,一些平台(例如Windows NT上的Win32子系统)不跟踪进程的父子关系。(NT是秘密的,但你必须调用未记录的API才能获取信息)

我很确定POSIX确实定义了这样的API,但我自己并没有使用过。