django - Celery - 有没有办法在中间的子任务失败后继续执行链

标签 django celery django-celery

我需要找到在任何中间子任务抛出异常后如何使用 immutable=True 子任务继续执行链的方式。

我已经读过这个 thread而这个 issue comment .现在这些错误已修复,但我需要实现相反的行为。我不需要停止我的链执行。可能还有另一个以任何顺序依次执行独立任务列表而不在它们之间发送结果的方法 ?我需要异步执行它们,因为在这种情况下 django-celery 将存储关于每个任务的统计信息。

一种解决方案是用以下内容覆盖所有子任务的主体:

try:
    ...
except Exception, e:
    logger.error('Exception raised: %s' % e)
    raise e

但在这种情况下,所有子任务都将使用 执行。成功 django-celery 管理界面中的异常状态和追溯将毫无用处。

最佳答案

Perharps 使用和弦和 CELERY_CHORD_PROPAGATES

因此,当 Chord 的一个子部分出现故障时,您可以管理异常并对其执行所需的操作(记录某些内容、重新排队任务以进行更改等)。

由于您已经拥有一个链,Chord 将只是其中的一部分,您需要了解状态的任务。

关于django - Celery - 有没有办法在中间的子任务失败后继续执行链,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15280399/

相关文章:

django - "django.db.utils.ProgrammingError: relation "auth_user "does not exist"Django V2.0

python - 使用 Google Compute Engine 时,“EntryPoint”对象没有属性 'resolve'

django - 在 django admin 中使用外部链接来创建或更新

django - 如何对 Django 模型字段求和

python - 我可以在不使用 djcelery 的情况下将 Celery v4.0.2 与 Django v1.7.1 一起使用吗?

redis - 运行时警告 :You're running the worker with superuser privileges:this is absolutely not recommended

python - 使用 HTML 模板在 python 中发送电子邮件

python - Django 调度和队列非周期性任务

具有多个速率限制的 celery

django - celery worker 仅在未分离时导入任务