celery-task - 使用 celery Group 时如何在子任务实例中获取组 ID?
问题描述
当使用 Celery 4.3.0 链时,代码如下:
class BaseTask(Task):
def on_success(self, retval, task_id, args, kwargs):
pass
@app.task(bind=True, base=BaseTask)
def add(self, x, y):
return x+y
@app.task(bind=True, base=baseTask)
def add_1(self,x, y):
return x+y
task = group(add.s(1,3), add_1.s(2,4))()
group_id = task.id
我可以通过 taks.children[0]._cache.get("group") 获取 group_id,
如何在 BaseTask on_success 函数中获取 group_id?
解决方案
您可以在对象中找到任务组的 ID,app.task.Request
通过Task
对象提供,如下所示:
class BaseTask(Task):
def on_success(self, retval, task_id, args, kwargs):
group_id = self.request.group
# rest of your code
推荐阅读
- python - 在 Python 中读取 CSV 文件,然后附加到现有密钥
- python - 如何在 GoogleColab 上安装 auto-sklearn?
- java - Selenide - 为每个 Junit 5 测试创建新驱动程序
- command-line-interface - NativeScript CLI 基础知识:设置后没有 main-page.xml 或 app.css 文件
- javascript - 将列表 Ajax(Json) 传递给 Controller C# MVC
- api - 如何确定 API 调用期间调用的所有函数的执行时间?
- amazon-web-services - Alexa 部署到 us-west-2?
- terminal - 如何以及是否在没有 Ncurses 的情况下为文本着色
- matlab - 如何在MATLAB中的图形的ylabel上写一个方程?
- php - 在进行注册之前检查用户是否登录