Python 用SIGKILL而不是SIGTERM杀死多处理池(我认为)

Python 用SIGKILL而不是SIGTERM杀死多处理池(我认为),python,selenium,unix,multiprocessing,Python,Selenium,Unix,Multiprocessing,因此,我有一个程序,利用多个selenium浏览器窗口的多处理 以下是该程序的外观: pool = Pool(5) results = pool.map_async(worker,range(10)) time.sleep(10) pool.terminate() 但是,这将等待池中的现有进程完成。我希望立即终止所有工作进程。多处理。池将工作进程列表存储在池中。_Poolattr,向他们发送信号很简单,然后: import multiprocessing import os import si

因此,我有一个程序,利用多个selenium浏览器窗口的多处理

以下是该程序的外观:

pool = Pool(5)
results = pool.map_async(worker,range(10))
time.sleep(10)
pool.terminate()

但是,这将等待池中的现有进程完成。我希望立即终止所有工作进程。

多处理。池将工作进程列表存储在
池中。_Pool
attr,向他们发送信号很简单,然后:

import multiprocessing
import os
import signal


def kill(pool):
    # stop repopulating new child
    pool._state = multiprocessing.pool.TERMINATE
    pool._worker_handler._state = multiprocessing.pool.TERMINATE
    for p in pool._pool:
        os.kill(p.pid, signal.SIGKILL)
    # .is_alive() will reap dead process
    while any(p.is_alive() for p in pool._pool):
        pass
    pool.terminate()

您是否尝试过
pool.kill()
?不幸的是,pool对象没有“kill”属性您的解决方案似乎对我不起作用(Python 3)=(我的主进程在调用
terminate
时卡住了。我还没有找到why@Dici我已经在python3.7下重新测试了它,没有发现任何错误。@georgexsh您可以在gist或pastebin中分享您的示例测试,看看我是否可以复制/比较我的情况吗?特别是当po上仍有正在运行的任务时,我会遇到这个问题ol,我希望所有人立即停止,程序停止exit@Dici,或者您可以提供。谢谢,我今晚将对此进行研究。我的代码有点复杂,将其简化为可共享的代码需要一些时间,这样做可能会消除阻止我的池死亡的因素。让我们看看您的代码片段可以帮我找到什么出局:)