用 python popen 后台 启动 appium 之后,出现自动结束进程的情况

python 复制代码
appium_port = get_free_appium_port()
cmd = f"appium -p {appium_port} &"
print(cmd)

subprocess.Popen(
   cmd,
   shell=True,
   # 这里修改
   stdout=open(f"./{appium_port}.log", "a+"),
   stderr=subprocess.STDOUT,
)

python(父进程)用subprocess.Popen新建一个进程(子进程)去开启一个shell, shell新开一个子进程(孙进程)去执行ping www.baidu.com的命令。

由于孙进程ping www.baidu.com一直在执行,就类似于一个daemon程序,一直在运行。

在超时时间后,父进程杀掉了shell子进程,但是父进程阻塞在了p.communicate函数了,是阻塞在了调用wait()函数之前,感兴趣的朋友可以看一下源码_communicate函数,linux系统重点看_communicate_with_poll和_communicate_with_select函数,你会发现是阻塞在了while循环里面,因为父进程一直在获取输出,而孙进程一直像一个daemon程序一样,一直在往子进程的输出写东西,而子进程的文件句柄继承自父进程。

虽然shell子进程被杀掉了,但是父进程里面的逻辑并没有因为子进程被意外的干掉而终止,(因为孙进程一直有输出到子进程的stdout,导致子进程的stdout一直有输出,也就是父进程的stdout也有输出),所以while循环一直成立,就导致了阻塞,进而导致wait()没有被调用,所以子进程没有被回收,就成了僵尸进程。

要完美的解决这个问题就是即要能获取到subprocess.Popen的进程的输出,在超时又要能杀掉子进程,让主进程不被阻塞。

相关推荐
gqkmiss5 天前
Electron 开发:获取当前客户端 IP
tcp/ip·electron·nodejs·os
MelonTe16 天前
golang单机锁实现
golang·os
诸神缄默不语1 个月前
如何用Python 3自动打开exe程序
python·os·subprocess·python 3
Nicn2 个月前
考研操作系统----操作系统的概念定义功能和目标(仅仅作为王道哔站课程讲义作用)
c++·考研·系统架构·操作系统·计算机组成原理·os
SunnyRivers2 个月前
go语言文件和目录
golang·文件·目录·os
HIT_Weston2 个月前
32、【OS】【Nuttx】OSTest分析(1):stdio测试(二)
文件系统·os·nuttx
wit_@2 个月前
【探索 Kali Linux】渗透测试与网络安全的终极操作系统
linux·运维·web安全·网络安全·os·kail
菠菠萝宝3 个月前
【Go学习】-01-4-项目管理及协程
数据库·学习·golang·操作系统·软件工程·协程·os
HIT_Weston3 个月前
19、【OS】【Nuttx】【Python】gdb调试优化,python实现构建脚本
python·gdb·os·nuttx
是十一月末4 个月前
Python模块之random、hashlib、json、time等内置模块语法学习
python·学习·json·random·os·datetime