Celery的复杂工作流程

时间:2016-10-02 11:17:58

标签: python celery

我正在尝试建立一个基于Celery的工作流程。我使用小组和和弦。

在下面的示例中,有独立的组([mytask1,mytask1,mytask1,..] - > myfinaltask1),其中mytask1可能并行执行,但myfinaltask1应在每个组之后调用基。

代码:

def func1(date):
    subtasks = []
    for filepath in all_files:
        kwargs = {'date': date, 'hfile': filepath}
        subtask = mytask1.subtask(kwargs=kwargs)
        subtasks.append(subtask)

    chrd = chord(subtasks)
    chrdr = chrd(myfinaltask1.s(kwargs={'date': date}))
    return chrdr


def main(all_dates):
    subtasks = []
    for ad in all_dates:
        subtasks.append(func1(ad))

    g = group(subtasks)
    gr = g.apply_async()
    results = gr.get(propagate=False)  # sync wait!


main([2014, 2015, 2016])

抛出异常:

File "/mypath/get_evi.py", line 265, in get_evi_year
    gr = g.apply_async()
File "/opt/venv/lib/python3.5/site-packages/celery/canvas.py", line 502, in apply_async
    type = self.type
File "/opt/venv/lib/python3.5/site-packages/celery/canvas.py", line 569, in type
    return self.app.tasks[self['task']]
File "/opt/venv/lib/python3.5/site-packages/celery/canvas.py", line 560, in app
    return self._app or (self.tasks[0].app if self.tasks else current_app)
AttributeError: 'bool' object has no attribute 'app'

我做错了什么?

1 个答案:

答案 0 :(得分:0)

您似乎忘记将subtasks包裹到group

def func1(date):
    subtasks = []
    for filepath in all_files:
        kwargs = {'date': date, 'hfile': filepath}
        subtask = mytask1.subtask(kwargs=kwargs)
        subtasks.append(subtask)

    chrd = chord(header=group(subtasks), body=myfinaltask1.subtask(kwargs={'date': date}))
    return chrdr