芹菜链:是否需要等待才能得到结果?
Celery chains: Is it necessary to wait before getting the results?
所以,我在 Python 3 中有一个 celery worker 运行s 的任务链。目前,我使用以下代码来获取并打印链的最终结果:
while not result.ready():
pass
print(result.get())
我有 运行 有和没有 while-loop 的代码,似乎 while-loop是多余的。
我的问题是:"is it necessary to have that while-loop?"
如果冗余是指代码在没有 while 循环的情况下也能正常工作,那么我敢说循环不是必需的。但是,如果您因为尝试打印尚不存在的内容而在没有循环的情况下抛出错误,那么您应该保留它。不过,这可能是个问题,因为一个空的 while 循环意味着您只是检查同一个变量的速度与您的计算机物理处理它的速度一样快,这往往会耗尽您的 CPU。我推荐如下内容:
import time
t = 1 #The number of seconds you want to wait between checking if the result is ready
while not result.ready():
time.sleep(t)
print(result.get())
您可以将 t
设置为任何有意义的值。如果您 运行 的任务需要几个小时,也许将其设置为 60,您将在一分钟内得到结果。如果你想更快地得到结果,你可以把间隔变小。这将防止程序拖累计算机的其余部分。然而,如果你不介意你的粉丝在吹,而且你绝对需要知道结果准备就绪的那一刻,请忽略以上所有内容,让你的代码保持原样:)
所以,我在 Python 3 中有一个 celery worker 运行s 的任务链。目前,我使用以下代码来获取并打印链的最终结果:
while not result.ready():
pass
print(result.get())
我有 运行 有和没有 while-loop 的代码,似乎 while-loop是多余的。
我的问题是:"is it necessary to have that while-loop?"
如果冗余是指代码在没有 while 循环的情况下也能正常工作,那么我敢说循环不是必需的。但是,如果您因为尝试打印尚不存在的内容而在没有循环的情况下抛出错误,那么您应该保留它。不过,这可能是个问题,因为一个空的 while 循环意味着您只是检查同一个变量的速度与您的计算机物理处理它的速度一样快,这往往会耗尽您的 CPU。我推荐如下内容:
import time
t = 1 #The number of seconds you want to wait between checking if the result is ready
while not result.ready():
time.sleep(t)
print(result.get())
您可以将 t
设置为任何有意义的值。如果您 运行 的任务需要几个小时,也许将其设置为 60,您将在一分钟内得到结果。如果你想更快地得到结果,你可以把间隔变小。这将防止程序拖累计算机的其余部分。然而,如果你不介意你的粉丝在吹,而且你绝对需要知道结果准备就绪的那一刻,请忽略以上所有内容,让你的代码保持原样:)