python 如何优雅地退出子进程
python 如何优雅地退出子进程
主进程产生子进程,子进程进入永久循环模式。当主进程要求子进程退出时,如何能安全地退出子进程呢?
参考一些代码,我写了这个例子。运行之后,用kill pid试试。pid是主进程的pid。当然子进程的也没问题。
1)如果kill pid为子进程的pid,当所有子进程都kill掉了,主进程就关闭了。这也是我们想要的结果。
2)如果kill pid为主进程的pid,主进程向子进程发送退出信号,然后等全部子进程关闭后退出。
保证了主进程在所有子进程退出之后退出。
#-*- coding: UTF-8 -*- # graceful_exit_event.py # UTF-8 without BOM # # refer: # http://stackoverflow.com/questions/26414704/how-does-a-python-process-exit-gracefully-after-receiving-sigterm-while-waiting?rq=1 # http://www.cnblogs.com/kaituorensheng/p/4445418.html # init created: 2016-07-13 # last updated: 2016-07-14 # ####################################################################### import os import signal import multiprocessing class GracefulExitException(Exception): @staticmethod def sigterm_handler(signum, frame): raise GracefulExitException() pass class GracefulExitEvent(object): def __init__(self): self.workers = [] self.exit_event = multiprocessing.Event() # Use signal handler to throw exception which can be caught # by worker process to allow graceful exit. signal.signal(signal.SIGTERM, GracefulExitException.sigterm_handler) pass def reg_worker(self, wp): self.workers.append(wp) pass def is_stop(self): return self.exit_event.is_set() def notify_stop(self): self.exit_event.set() def wait_all(self): while True: try: for wp in self.workers: wp.join() print "main process(%d) exit." % os.getpid() break except GracefulExitException: self.notify_stop() print "main process(%d) got GracefulExitException." % os.getpid() except Exception, ex: self.notify_stop() print "main process(%d) got unexpected Exception: %r" % (os.getpid(), ex) break pass ####################################################################### def worker_proc(gee): import sys, time print "worker(%d) start ..." % os.getpid() try: while not gee.is_stop(): # do task job here print ".", time.sleep(1) else: print "" print "worker process(%d) got exit event." % os.getpid() print "worker process(%d) do cleanup..." % os.getpid() time.sleep(1) print "[%d] 3" % os.getpid() time.sleep(1) print "[%d] 2" % os.getpid() time.sleep(1) print "[%d] 1" % os.getpid() except GracefulExitException: print "worker(%d) got GracefulExitException" % os.getpid() except Exception, ex: print "Exception:", ex finally: print "worker(%d) exit." % os.getpid() sys.exit(0) if __name__ == "__main__": import sys print "main process(%d) start" % os.getpid() gee = GracefulExitEvent() # Start some workers process and run forever for i in range(0, 10): wp = multiprocessing.Process(target=worker_proc, args=(gee,)) wp.start() gee.reg_worker(wp) gee.wait_all() sys.exit(0)
需要说明的是:
如果某个进程接受 kill pid,必须在该进程函数的最外层捕获: except GracefulExitException,
同时该进程函数内部调用捕获了 except Excetion,则必须在之前捕获GracefulExitException,
即:
(2) 必须在(3)之前。否则同时去掉(2)和(3)。
def do_some_func(): try: time.sleep(10) blablabla (1) except SomeError: # 捕获特定的异常 pass (2) except GracefulExitException: # 接收 kill pid pass (3) except: # 不建议捕获默认异常, 否则必须在此之前捕获:GracefulExitException pass def some_process_main(gee): try: while not gee.is_stop(): do_some_func() except GracefulExitException: # 接收到了 kill pid, 设置中止循环 gee.notify_stop() pass except: pass
python 如何优雅地退出子进程的更多相关文章
- 如何优雅地退出python程序
如何优雅地退出python程序 一个单模的python程序,启动之后要能够优雅地关闭.即当用户按Ctrl+C或者kill pid的时候,程序都能从容关闭.实现起来非常简单. is_running = ...
- 情景linux--如何优雅地退出telnet
情景linux--在脚本中如何优雅地退出telnet 情景 telnet命令是TELNET协议的用户接口,它支持两种模式:命令模式和会话模式.虽然telnet支持许多命令,但大部分情况下,我们只是使用 ...
- C# Note11:如何优雅地退出WPF应用程序
前言 I should know how I am supposed to exit my application when the user clicks on the Exit menu item ...
- 从nsq中学习如何优雅的退出go 网络程序
退出运行中的程序,可以粗暴的kill -9 $PID,但这样会破坏业务的完整性,有可能一个正在在执行的逻辑半途而费,从而产生不正常的垃圾数据. 本文总结在go语言中,如何能优雅的退出网络应用,涉及的知 ...
- 如何优雅的退出/关闭/重启gunicorn进程
在工作中,会发现gunicorn启动的web服务,无论怎么使用kill -9 进程号都是无法杀死gunicorn,经过我一番百度和谷歌,发现想要删除gunicorn进程其实很简单. 1. 寻找mast ...
- 【Golang】程序如何优雅的退出?
1. 背景 项目开发过程中,随着需求的迭代,代码的发布会频繁进行,在发布过程中,如何让程序做到优雅的退出? 为什么需要优雅的退出? 你的 http 服务,监听端口没有关闭,客户的请求发过来了,但处理了 ...
- 让Python更优雅更易读(第二集)
友情链接 让Python更优雅更易读(第一集) 1.装饰器 1.1装饰器特别适合用来实现以下功能 运行时校验:在执行阶段进行特定校验,当校验通不过时终止执行. 适合原因:装饰器可以方便地在函数执行前介 ...
- [转载]Python模块学习 ---- subprocess 创建子进程
[转自]http://blog.sciencenet.cn/blog-600900-499638.html 最近,我们老大要我写一个守护者程序,对服务器进程进行守护.如果服务器不幸挂掉了,守护者能即时 ...
- 一个Python中优雅的数据分块方法
背景 看到这个标题你可能想一个分块能有什么难度?还值得细说吗,最近确实遇到一个有意思的分块函数,写法比较巧妙优雅,所以写一个分享. 日前在做需求过程中有一个对大量数据分块处理的场景,具体来说就是几十万 ...
随机推荐
- 深入java多线程一
涉及到 1.线程的启动(start) 2.线程的暂停(suspend()和resume()) 3.线程的停止(interrupt与异常停止,interrupt与睡眠中停止,stop(),return) ...
- mysql事务,视图,权限管理,索引,存储引擎(胖胖老师)
1: 视图什么是视图 视图是一个虚拟表, 它的内容来源于查询的实表, 本身没有真正的数据;视图的作用 对于复杂的查询时,每次查询时都需要编写一些重复的查询代码让编写sql的效率低下, 为了 ...
- ASP.NET MVC 中 View 的设计
1. 前言 感觉有好长时间没有接触View 了,周末闲来无事,翻翻书桌上的书来回顾回顾ASP.NET MVC中View的相关内容. 2. View概述 View 通过应用程序在Action 中返回 ...
- [JLOI 2014]松鼠的新家
Description 松鼠的新家是一棵树,前几天刚刚装修了新家,新家有n个房间,并且有n-1根树枝连接,每个房间都可以相互到达,且俩个房间之间的路线都是唯一的.天哪,他居然真的住在”树“上. 松鼠想 ...
- clique
[题目描述]数轴上有 n 个点,第 i 个点的坐标为 xi,权值为 wi.两个点 i,j 之间存在一条边当且仅当 abs(xi-xj)>=wi+wj.你需要求出这张图的最大团的点数.(团就是两两 ...
- [BZOJ]2589: Spoj 10707 Count on a tree II
Time Limit: 20 Sec Memory Limit: 400 MB Description 给定一棵N个节点的树,每个点有一个权值,对于M个询问(u,v),你需要回答u xor last ...
- hdu 5314 动态树
Happy King Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Tot ...
- 2015 多校联赛 ——HDU5316(线段树)
Fantasy magicians usually gain their ability through one of three usual methods: possessing it as an ...
- hdu 5130(2014广州 圆与多边形相交模板)
题意:一个很多个点p构成的多边形,pb <= pa * k时p所占区域与多边形相交面积 设p(x,y), (x - xb)^2+(y - yb)^2 / (x - xa)^2+(y ...
- 51Nod 1125 交换机器的最小代价
题目描述: 有N台机器重量各不相等,现在要求把这些机器按照重量排序,重量从左到右依次递增.移动机器只能做交换操作,但交换机器要花费一定的费用,费用的大小就是交换机器重量的和.例如:3 2 1,交换1 ...