栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

捕获Ctrl + C / SIGINT并在python中优雅退出多进程

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

捕获Ctrl + C / SIGINT并在python中优雅退出多进程

正确的方法来处理

Ctrl+C
/
SIGINT
multiprocessing.Pool
是:

  1. SIGINT
    Pool
    创建流程之前,请忽略该流程。这样创建的子进程继承了
    SIGINT
    处理程序。
  2. 创建
    SIGINT
    a之后,在父进程中还原原始处理程序
    Pool
  3. 使用
    map_async
    apply_async
    代替阻塞
    map
    apply
  4. 等待结果超时,因为默认阻塞将等待忽略所有信号。这是Python错误https://bugs.python.org/issue8296。

把它放在一起:

#!/bin/env pythonfrom __future__ import print_functionimport multiprocessingimport osimport signalimport timedef run_worker(delay):    print("In a worker process", os.getpid())    time.sleep(delay)def main():    print("Initializng 2 workers")    original_sigint_handler = signal.signal(signal.SIGINT, signal.SIG_IGN)    pool = multiprocessing.Pool(2)    signal.signal(signal.SIGINT, original_sigint_handler)    try:        print("Starting 2 jobs of 5 seconds each")        res = pool.map_async(run_worker, [5, 5])        print("Waiting for results")        res.get(60) # Without the timeout this blocking call ignores all signals.    except KeyboardInterrupt:        print("Caught KeyboardInterrupt, terminating workers")        pool.terminate()    else:        print("Normal termination")        pool.close()    pool.join()if __name__ == "__main__":    main()

正如@YakovShklarov指出的那样,在父进程中忽略信号和忽略信号之间存在时间窗口,在此期间信号可能会丢失。

pthread_sigmask
在父进程中使用临时阻止信号的传递可以防止信号丢失,但是在Python-2中不可用。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/650912.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号