3

我正在做这样的事情

def exitHandler(self, *args):
    self.stopThreads()
    sys.exit(2)

我在 self.run 中注册了该功能(使用守护程序)

   signal.signal(signal.SIGTERM, self.exitHandler)

self.stopThreads() 有时需要一段时间才能完成。我正在停止由这些线程启动的子进程。当信号处理程序被多次调用时,我会收到如下错误消息:

Exception SystemExit: 2 in <bound method Popen.__del__ of <subprocess.Popen object at 0x929d10c>> ignored

一切都很好,即使我的所有进程都忽略了异常,线程也应该完成。我很好奇我做错了什么以及如何摆脱被忽略的异常错误。

4

1 回答 1

2

问题似乎是其中一个stopThreads()sys.exit()不是可重入的工作,并且第二个 SIGTERM 导致其中一个或两个在其自身中间被调用。

现在,您无法阻止 SIGTERM 多次交付,但您可以重新设计逻辑以适应它。通常(通常是正确的)建议是重构您的信号处理程序以简单地设置一个标志,并在您的主循环中检查该标志:

def termHandler(self, *args):
    global flag_exit
    global exit_code

    flag_exit = True
    exit_code = 2


... in the main loop ...

    while not flag_exit:
        do_work()

    self.stopThreads()
    sys.exit(exit_code)
于 2013-07-18T16:39:52.797 回答