从终端分离的过程仍然向终端输出Traceback



在测试我使用rest api制作的应用程序时,我发现了这种我不理解的行为
让我们从如下再现类似的错误开始-
在文件call.py中-
注意此文件具有可视化的代码,例如永远运行的GUI。在这里,我只是向您展示一个陈述,并故意让它提出一个例外,向您展示这个问题。发出一个get请求,然后尝试将结果解析为json,这将引发一个JSONDecodeError

import requests
from time import sleep
sleep(3)
uri = 'https://google.com'
r = requests.get(uri)
response_dict = r.json()

由于我想将其作为守护进程运行,因此我使用以下技巧将该进程与启动它的终端解耦-
在文件start.py-中

import subprocess
import sys
subprocess.Popen(["python3", "call.py"])
sys.exit(0)

然后我执行python3 start.py
它显然解耦了过程,因为如果没有异常,视觉表现会完美运行
但是,如果出现异常,我会立即在终端中看到此输出,即使我在调用python3 start.py-后得到了新的提示

$ python3 start.py
$ Traceback (most recent call last):
File "call.py", line 7, in <module>
response_dict = r.json()
File "/home/walker/.local/lib/python3.6/site-packages/requests/models.py", line 896, in json
return complexjson.loads(self.text, **kwargs)
File "/usr/lib/python3/dist-packages/simplejson/__init__.py", line 518, in loads
return _default_decoder.decode(s)
File "/usr/lib/python3/dist-packages/simplejson/decoder.py", line 370, in decode
obj, end = self.raw_decode(s)
File "/usr/lib/python3/dist-packages/simplejson/decoder.py", line 400, in raw_decode
return self.scan_once(s, idx=_w(s, idx).end())
simplejson.errors.JSONDecodeError: Expecting value: line 1 column 1 (char 0)

现在,我明白了所有异常都必须在程序本身中处理。在这个奇怪的问题之后,我已经这样做了,但我不清楚的是为什么会发生这种情况
如果我退出终端并重新启动终端,就不会发生这种情况(在Traceback的情况下,视觉表现会被卡住,并且在任何终端上都没有预期的输出(
为什么解耦的过程会这样
注意:解耦对我来说是必不可少的。GUI必须作为后台进程或守护进程运行,并且生成它的终端必须从中释放出来。

by"去耦";,我想你的意思是希望stdout/stderr转到/dev/null?假设这就是你的意思,那不是你告诉你的代码做的

来自文档:

stdin、stdout和stderr分别指定执行程序的标准输入、标准输出和标准错误文件句柄。有效值为PIPEDEVNULL、现有文件描述符(正整数(、现有文件对象和None

默认设置为None时,不会发生重定向;子级的文件句柄将从父级继承。

因此,您可能想要执行以下操作:

from subprocess import Popen, DEVNULL
Popen(["python3", "call.py"], stdin=DEVNULL, stdout=DEVNULL, stderr=DEVNULL)

根据OP的评论,我认为他们可能是在追求像GNUscreentmux这样的工具。像这样的终端多路复用器允许您创建一个虚拟终端,您可以在需要时断开连接并重新连接到该终端。这些答案参见https://askubuntu.com/a/220880/106239和https://askubuntu.com/a/8657/106239分别有tmuxscreen的示例

最新更新