芹菜任务的中间件

Middleware for celery tasks

目前我们在应用程序中使用了大量的 celery 任务,我们有一个异常可能会引发大量任务。

我们可以在每个任务中创建一个 try 和 catch 块并相应地处理这个特定的异常,但正在寻找一种方法来捕获任何任务(如中间件行)的任何异常以便于维护。

谁能指点一下?

我们正在使用以下版本:

celery==3.1.18
django-celery==3.1.16
Django==1.6.5

这可以使用基本抽象任务处理程序来完成。特别是对于异常,有一个 on_failure 处理程序。

from celery import Task

class MyBaseTask(Task):
    abstract = True

    def on_failure(self, exc, task_id, args, kwargs, einfo):
        # Task failed. What do you want to do?
        print('Task raised an exception: {}'.format(exc)

@app.task(base=MyBaseTask)
def my_task():
    # Your task code

有关可用处理程序和传递给每个处理程序的参数的更多信息,请参阅 Celery 文档:http://docs.celeryproject.org/en/latest/userguide/tasks.html#abstract-classes