使用evenlet包实现 concurrent.futures.executor包的鸭子类
Posted ydf0509
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用evenlet包实现 concurrent.futures.executor包的鸭子类相关的知识,希望对你有一定的参考价值。
适配成同一个同样的公有方法。
# -*- coding: utf-8 -*- # @Author : ydf # @Time : 2019/7/3 10:35 import time import warnings from eventlet import greenpool, monkey_patch, patcher, Timeout from app.utils_ydf import LogManager, nb_print def check_evenlet_monkey_patch(raise_exc=True): if not patcher.is_monkey_patched(‘socket‘): if raise_exc: warnings.warn(f‘检测到没有打 evenlet 包的猴子补丁 ,请在文件首行加上 import eventlet;eventlet.monkey_patch(all=True) ‘) raise Exception(‘检测到没有打 evenlet 包的猴子补丁 ,请在文件首行加上 import eventlet;eventlet.monkey_patch(all=True)‘) else: return 1 logger_evenlet_timeout_deco = LogManager(‘logger_evenlet_timeout_deco‘).get_logger_and_add_handlers() def evenlet_timeout_deco(timeout_t): def _evenlet_timeout_deco(f): def __evenlet_timeout_deco(*args, **kwargs): timeout = Timeout(timeout_t, ) # timeout.start() # 与gevent不一样 try: f(*args, **kwargs) except Timeout as t: logger_evenlet_timeout_deco.error(f‘函数 f 运行超过了 timeout_t 秒‘) if t is not timeout: nb_print(t) # raise # not my timeout finally: timeout.cancel() return __evenlet_timeout_deco return _evenlet_timeout_deco class CustomEventletPoolExecutor(greenpool.GreenPool): def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) check_evenlet_monkey_patch() def submit(self, *args, **kwargs): # 保持为一直的公有用法。 # nb_print(args) self.spawn_n(*args, **kwargs) # self.spawn_n(*args, **kwargs) def shutdown(self): self.waitall() if __name__ == ‘__main__‘: # greenpool.GreenPool.waitall() monkey_patch(all=True) def f2(x): time.sleep(1) nb_print(x) pool = CustomEventletPoolExecutor(4) for i in range(15): nb_print(f‘放入i‘) pool.submit(evenlet_timeout_deco(0.8)(f2), i)
以上是关于使用evenlet包实现 concurrent.futures.executor包的鸭子类的主要内容,如果未能解决你的问题,请参考以下文章
R语言ggplot2可视化为组合图添加综合图例实战:使用ggpubr包ggarrange函数实现综合图例使用patchwork包实现综合图例