broker_url = 'amqp://guest:guest@localhost:5672/my_vhost' task_routes = { 'project.task.create_order': { 'queue': 'succeed' }, } imports = [ 'project.task', ]
@app.task def hello(msg): sleep(2) print('hello') @app.task def create_order(data): sleep(2) print('create_order')
我的设想是 create_order 会自动处理 succeed 里面的消息, 而 hello 是需要的时候手动调用
以下面的命令启动后:
celery -A project.main worker -l info -Q succeed -P eventlet -E
create_order 正常工作, 但调用 hello 没反应
celery -A project.main worker -l info -P eventlet -E
去掉 -Q succeed 的话就相反了, hello 可以正常调用, 但 create_order 就不工作...
我记得我以前试过是可以同时工作的?
![]() | 1 ifoolish 2019-12-08 18:55:19 +08:00 问题很明显了。你的配置文件中 create_order 指定了队列 succeed,你运行 worker 的参数 -Q succeed 也指定了这是 处理 succeed 队列的 worker,那当然只会执行 create_order 啊,想要 hello 也会得到执行,你再多开一个处理默认队列的 worker 进程就行了,也就是不加 -Q 参数 |
![]() | 2 ifoolish 2019-12-08 18:59:34 +08:00 或者你只想开一个 worker 进程的话,-Q 参数加上默认队列的名字,即-Q succeed,celery。仔细看看文档吧 |
3 aoscici2000 OP @ifoolish 谢谢, 确实如此, celery 貌似是自动生成了队列, 没留意到 |