1
我在两台机器上有两个芹菜节点(n1,n2),我的任务入队在另一台机器上(主)。 主机可能不知道可用的节点名称。 我的问题是,是否有任何保证任务链将在单个节点上运行。Python芹菜在单个节点上的任务链
res = chain(generate.s(filePath1, filePath2), mix.s(), sort.s())
问题是各种任务都使用本地数据文件,这些文件是特定于节点的。 我的猜测是,链可能是和弦,文档明确表示,不能保证在单个节点上运行。 如果我对链条的猜测是正确的,那么我的下一个问题是,以下是链接的替代方案的一个很好的解决方案吗?
单任务=保证单个节点
@app.task
def my_chain_of_tasks():
celery.current_app.send_task('mymodel.tasks.generate', args=[filePath1, filePath2]).get()
celery.current_app.send_task('mymodel.tasks.mix').get()
# do these 2 in parallel:
res1 = celery.current_app.send_task('mymodel.tasks.sort')
res2 = celery.current_app.send_task('mymodel.tasks.email_in_parallel')
res1.get()
return res2.get()
,或者这是仍然要任务发送到消息队列和导致同样的问题?
我有点困惑。我可以在主机上指定CELERY_ROUTES吗?主机不运行芹菜。它只是排队消息队列中的任务。 – max
那很好。你可以在celery配置文件中指定路由。当您在远程计算机上运行worker时,它只会消耗来自代理 – ChillarAnand
的相关任务,谢谢。让我想出一个设置来尝试一下;那么我会标记你的答案。 – max