簡體   English   中英

如果程序在 < 10 秒內崩潰,則 Python 子進程讀取 stdout/stderr

[英]Python subprocess reading stdout/stderr if the program crashes in < 10 seconds

我有一個腳本,它調度不同程序的長時間運行,該程序有時可以並行運行(即我可以多次調用下面的函數)。 我想解雇並忘記這些孩子,所以我目前有:

p = subprocess.Popen(cmd, shell=False)
time.sleep(20)
result = p.poll()
if result is not None and result != 0:
    print("Child failed to start with exit code: {}".format(result))
    return False
return True

這在大多數情況下效果很好,但我想為孩子獲取標准輸出/標准錯誤,但僅在它無法運行超過 10 秒的情況下。

根據我的理解,使用Popen(..., stdout=PIPE)意味着如果我只是忽略子進程對象,那么緩沖區將填滿,子進程將掛起。

我該如何解決這個問題,使其不會掛起。 是否有可能以某種方式將 PIPE 換成 None 。

p = subprocess.Popen(cmd, shell=False, stdout=PIPE, stderr=PIPE)
time.sleep(20)
result = p.poll()
if result is not None and result != 0:
    print("Child failed to start with exit code: {}".format(result))
    stdout, stderr = p.communicate()
    print("STDOUT:", stdout)
    print("STDERR:", stderr)
    return False
return True

假設我可以輕松地將在前 10 秒內生成的輸出保存在緩沖區中也是安全的。

一種簡單的方法是讓所有孩子都寫入臨時文件 ( https://docs.python.org/2/library/tempfile.html )。 只需寫入那里而不是管道,並僅在需要時讀取文件(如果發生崩潰)。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM