本文整理汇总了Python中threading.Timer.expired方法的典型用法代码示例。如果您正苦于以下问题:Python Timer.expired方法的具体用法?Python Timer.expired怎么用?Python Timer.expired使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类threading.Timer
的用法示例。
在下文中一共展示了Timer.expired方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: run_command_with_timeout
# 需要导入模块: from threading import Timer [as 别名]
# 或者: from threading.Timer import expired [as 别名]
def run_command_with_timeout(cmd, timeout_sec):
"""Execute `cmd` in a subprocess and enforce timeout `timeout_sec` seconds.
Return subprocess exit code on natural completion of the subprocess.
Raise an exception if timeout expires before subprocess completes."""
proc = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, shell=True, preexec_fn=os.setsid)
print proc.pid
def kill_proc():
print 'kill proc timer!'
timer.expired = True
os.killpg(proc.pid, signal.SIGTERM)
# proc.terminate()
timer = Timer(timeout_sec, kill_proc)
timer.expired = False
timer.start()
stdout_value, stderr_value = proc.communicate()
if timer.expired:
# Process killed by timer - raise exception
return 'timeout', proc.returncode, stdout_value, stderr_value
# Process completed naturally - cancel timer and return exit code
timer.cancel()
return 'done', proc.returncode, stdout_value, stderr_value