0

我正在测试 Django + Celery,hello world 示例。使用 RabbitMQ celery 可以正常工作,但是当我切换到 Redis 代理/结果时,我得到以下信息:

%timeit add.delay(1,2).get()
1 loops, best of 3: 503 ms per loop

设置.py

CELERY_RESULT_BACKEND = "redis"
BROKER_URL = 'redis://localhost:6379'

任务.py

@task()
def add(x, y):
    return x + y

上面的测试有问题吗?

4

1 回答 1

1

我发现解决方案是源代码: http ://docs.celeryproject.org/en/latest/_modules/celery/result.html#AsyncResult.get

间隔- 在重试检索结果之前等待的时间(以秒为单位)。请注意,这在使用 amqp 结果存储后端时没有任何影响,因为它不使用轮询。

默认为 0.5 秒。您可以手动更改它,但不推荐运行任务的方式:

%timeit add.delay(1,2).get(interval=0.001)
100 loops, best of 3: 3.92 ms per loop
于 2013-03-13T13:44:40.577 回答