从python gevent输出中删除stacktrace

时间:2019-02-28 00:55:30

标签: python gevent spawn greenlets

我是python的新手,尝试在引发异常时删除/修剪gevent stacktrace输出。我在某处读到可以使用AsyncResult来实现它,但是似乎我不知道如何使用它。

这里是一个示例,我反复进行迭代以使其类似于要进行故障排除的真实代码,但是当我尝试将my_decor添加到work()时,我陷入了最后一个阶段。 修复此问题的任何帮助将不胜感激。

from gevent.event import AsyncResult
import gevent
from functools import wraps


def my_decor(k, *args, **kwargs):
    @wraps(k)
    def wrapper(*args, **kwargs):
        r = AsyncResult()
        try:
            value = k()
        except Exception as e:
            r.set_exception(e)
        else:
            r.set(value)
        return r.exception or r.value
    result = gevent.spawn(wrapper, k)
    return result


def f():
    def foo():
        if True:
                raise Exception('tttttttt')
    return foo


def p():
    def bar():
        if True:
                raise Exception('ppppppppppppp')
    return bar


@my_decor
def work():
    foo1 = gevent.spawn(f())
    bar1 = gevent.spawn(p())
    gevent.joinall([foo1, bar1])
    return foo1.get() or bar1.get()

1 个答案:

答案 0 :(得分:0)

找到了答案,认为这可能会对那些有相同问题的人有所帮助。

from gevent.event import AsyncResult
import gevent
from functools import wraps


def my_decor(k):
    @wraps(k)
    def wrapper(*args, **kwargs):
        r = AsyncResult()
        try:
            value = k(*args, **kwargs)
        except Exception as e:
            r.set_exception(e)
        else:
            r.set(value)
        return r.exception or r.value
    return wrapper


def f(msg):
    @my_decor
    def foo():
        if True:
            raise Exception('tttttttt %s' % msg)
#           print('test')
    return foo


def p(msg):
    @my_decor
    def bar():
        if True:
            raise Exception('ppppppppppppp %s', msg)
    return bar


def work():
    test = "test"
    seti = "set"
    foo1 = gevent.spawn(f(test))  # returns a function that coroutine uses
    bar1 = gevent.spawn(p(seti))
    gevent.joinall([foo1, bar1])
    return foo1.get() or bar1.get()


res = work()
print res
相关问题