使用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包实现综合图例

可以使用 ***Service 实现来捕获和发送数据包吗?

在 R 中使用 LongituRF 包实现纵向随机森林

如何使用模板参数包实现 SFINAE 仅限于少数类型

C语言如何实现POST数据包

网络编程 之粘包问题使用socketserver实现并发