芹菜:打印以apply\u asyn开始的组中每个任务的状态

2024-09-25 10:31:25 发布

您现在位置:Python中文网/ 问答频道 /正文

我试图打印4个远程任务的状态,从组中的每个AsyncResult获取信息。你知道吗

到目前为止,我可以打印状态,但不能打印生成(或尚未生成)AsyncResult的任务的名称(请参阅下面的控制台打印)

我遇到的另一个问题是,虽然组是用apply\u async(expires=30)启动的,但是没有过期,只要有一个子任务“PENDING”,循环就永远继续。你知道吗

from celery import group

ping_results = group(
    ping_portal.s(),
    ping_factory.s(),
    ping_factory_m.s(),
    ping_proxy.s()
).apply_async(expires=30)

while ping_results.waiting():

    c = ping_results.completed_count()

    print("{0} nodes have responded".format(c))

    for c in ping_results.children:
        print("{0}: {1}".format(c, c.status))

控制台:

3 nodes have responded
33cae071-8944-4a56-9cc1-d0c83bfb0a20: PENDING
97f9a481-8d31-4889-9ea2-6f43d7561443: SUCCESS
8f030dfe-e235-4794-8a84-bf583992528a: SUCCESS
b971a4ac-d23f-4378-b8b6-2c55f3d05618: SUCCESS

Tags: async状态factoryhavegrouppingresultssuccess
1条回答
网友
1楼 · 发布于 2024-09-25 10:31:25

由于^{}children属性只是一系列AsyncResult实例,因此它应该能够通过结果的name属性获得任务名称,例如

for c in ping_results.children:
    print("{0}[{1}]: {2}".format(c.name, c, c.status))

相关问题 更多 >