gpt4 book ai didi

python - celery 过期 - 引发异常

转载 作者:太空狗 更新时间:2023-10-30 02:34:10 25 4
gpt4 key购买 nike

在文档中 link关于过期

# Task expires after one minute from now.
add.apply_async(args=[10, 10], expires=60)

我使用:

from tasks import add
result = add.apply_async(args=[10, 10], expires=6000)
printus(result)

def printus(result):
print (result) #task id
print (result.ready()) # returns True if the task has finished processing.
print (result.result) # task is not ready, so no return value yet.
print (result.get()) # Waits until the task is done and returns the retval.
print (result.result) # direct access to result, doesn't re-raise errors.
print (result.successful()) # returns True if the task didn't end in failure.)

任务.py

from celery.task import task
@task
def add(x, y):
return x + y

在 celery 中:

[2012-03-21 19:50:03,012: WARNING/MainProcess] Skipping revoked task: tasks.add[4ffcff91-b12b-4bce-8d47-159314759859]

在控制台中:

4ffcff91-b12b-4bce-8d47-159314759859
True

Traceback (most recent call last):
File "/home/echeg/Dropbox/my_py/opoveshun/tests/celery/run_task.py", line 53, in <module>
tr.countdown()
File "/home/echeg/Dropbox/my_py/opoveshun/tests/celery/run_task.py", line 26, in countdown
self.printus(result)
File "/home/echeg/Dropbox/my_py/opoveshun/tests/celery/run_task.py", line 48, in printus
print (result.get()) # Waits until the task is done and returns the retval.
File "/usr/local/lib/python2.7/dist-packages/celery/result.py", line 95, in get
interval=interval)
File "/usr/local/lib/python2.7/dist-packages/celery/backends/amqp.py", line 144, in wait_for
raise self.exception_to_python(meta["result"])
celery.exceptions.TaskRevokedError

为什么会出现异常?结果还没过期

如果我使用:

result = add.apply_async(args=[10, 10])

一切顺利

226107de-f739-4860-83bc-d843f17a257e
False
None
20
20
True

最佳答案

celeryd 认为你的任务已经过期:

[2012-03-21 19:50:03,012: WARNING/MainProcess] Skipping revoked task: tasks.add[4ffcff91-b12b-4bce-8d47-159314759859]

当工作人员拿起过期任务时,it revokes it不执行。检查您的时区设置?我遇到了相反的问题:任务没有在应该到期的时候到期。这为我修好了:

CELERY_ENABLE_UTC = True
CELERY_TIMEZONE = 'Etc/UTC'

关于python - celery 过期 - 引发异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9806081/

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