linux中进程呈现树状结构,一个进程可能有若干个子进程,最多有一个父进程。在文件/proc/$pid/task/$pid/children中存放了该进程的子进程号,用空格分隔。
ljq@ljq1:/home/fujx/controller$ cat /proc/1/task/1/children
313 337 352 750 906 920 928 1011 1015 1018 1025 1078 1226 1274 1360 1432 1489 1523 1935 2032 2034 2075 2430 2554 2581 3021 3071 13972 13976
该文件不能直接访问到子进程的子进程,但是由于知道了子进程的pid,因此可以再访问子进程对应的children文件,找到孙进程,递归找到所有的后代进程。
使用深度优先搜索和广度优先搜索的方式都能达到目的,下面展示深度优先的代码
def collectPids(pid):
pid_list =

本文介绍了如何在Linux环境下,利用Python遍历进程树,通过深度优先搜索获取进程组中所有子进程的进程号。这种方法首先从父进程的PID入手,递归查找其子进程及子孙进程。
最低0.47元/天 解锁文章
182

被折叠的 条评论
为什么被折叠?



