芹菜:按任务ID获取功能名称?

时间:2015-05-12 06:41:51

标签: python celery

我正在使用celery on_failure处理程序来记录所有失败的任务以进行调试和分析。我想知道失败任务的任务名称(函数名称),我该怎么做?

from celery import Task

class DebugTask(Task):
    abstract = True

    def after_return(self, *args, **kwargs):
        print('Task returned: {0!r}'.format(self.request))

    def on_failure(self, exc, task_id, args, kwargs, einfo):
        func_name = get_func_name_by_task_id(task_id) # how do I do this?
        print "{} failed".format(func_name)           # expected out: add failed.

@app.task(base=DebugTask)
def add(x, y):
    return x + y

PS:我知道有task_id,但task_id每次查询函数名称都不好玩,

1 个答案:

答案 0 :(得分:3)

快速查看文档显示Task.name