【发布时间】:2019-01-08 22:00:28
【问题描述】:
我正在使用以下堆栈:
- Python 3.6
- Celery v4.2.1(代理:RabbitMQ v3.6.0)
- Django v2.0.4。
根据Celery's documentation,在不同的队列上运行计划任务应该就像为CELERY_ROUTES上的任务定义相应的队列一样简单,但所有任务似乎都在Celery的默认队列上执行。
这是my_app/settings.py上的配置:
CELERY_BROKER_URL = "amqp://guest:guest@localhost:5672//"
CELERY_ROUTES = {
'app1.tasks.*': {'queue': 'queue1'},
'app2.tasks.*': {'queue': 'queue2'},
}
CELERY_BEAT_SCHEDULE = {
'app1_test': {
'task': 'app1.tasks.app1_test',
'schedule': 15,
},
'app2_test': {
'task': 'app2.tasks.app2_test',
'schedule': 15,
},
}
这些任务只是用于测试路由的简单脚本:
文件app1/tasks.py:
from my_app.celery import app
import time
@app.task()
def app1_test():
print('I am app1_test task!')
time.sleep(10)
文件app2/tasks.py:
from my_app.celery import app
import time
@app.task()
def app2_test():
print('I am app2_test task!')
time.sleep(10)
当我使用所有必需的队列运行 Celery 时:
celery -A my_app worker -B -l info -Q celery,queue1,queue2
RabbitMQ 将显示只有默认队列“celery”正在运行任务:
sudo rabbitmqctl list_queues
# Tasks executed by each queue:
# - celery 2
# - queue1 0
# - queue2 0
有人知道如何解决这种意外行为吗?
问候,
【问题讨论】:
标签: django python-3.x celery python-3.6 django-celery