gpt4 book ai didi

python - Networkx 作为任务队列?

转载 作者:太空宇宙 更新时间:2023-11-03 12:04:34 26 4
gpt4 key购买 nike

我在 networkx 中有一个有向无环图。每个节点代表一个任务,节点的前任是任务依赖项(给定任务在其依赖项执行之前无法执行)。

我想在异步任务队列中“执行”图形,类似于 celery 提供的功能(以便我可以轮询作业的状态、检索结果等)。 Celery 不提供创建 DAG 的能力(据我所知),并且一旦所有依赖项都完成就能够继续执行 task 将是至关重要的(DAG 可能有多个路径和即使一项任务很慢/阻塞,也有可能继续执行其他任务等)。

是否有关于我如何实现这一点的任何简单示例,或者甚至可以将 networkxcelery 集成?

最佳答案

您可以为此使用的一个库是 taskgraph .它允许您定义任务图,然后以多线程/多进程的方式执行这些任务。它避免了重新运行结果已经是最新的任务,类似于 make 程序。

要执行您的 networkx 图,您将迭代 topological order 中的所有节点。 ,收集每个的即时依赖项,并调用 task_graph.add_task。此函数将返回新添加任务的句柄,这使您可以将其用作后续添加任务的依赖项(这就是节点迭代顺序很重要的原因)

有关替代解决方案,另请参阅 this question .

关于python - Networkx 作为任务队列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36113114/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com