celery 广播问题

2018-07-07 15:10:35 +08:00
 ray1888

我按官网文档上面的来添加了这段代码在 celery_config 里面

CELERY_QUEUES = (Broadcast(name='broadcast_tasks',),)

#
CELERY_ROUTES = {
    'celery_task.method.get_new_method': {
      'queue': 'broadcast_tasks',
      # 'exchange': Exchange(type='fanout')
    }
}

启动的时候会直接报错

PreconditionFailed: Exchange.declare: (406) PRECONDITION_FAILED - inequivalent arg 'type' for exchange 'broadcast_tasks' in vhost '/': received 'fanout' but current is 'direct'

环境是 py2.7+ celery4.2 + rabbitmq 3.6 是什么原因导致这个问题,搜了 stackoverflow 也没看到有好的解决方法

2444 次点击
所在节点    程序员
2 条回复
ray1888
2018-07-07 16:38:21 +08:00
换了使用在 app 文件中启动前加了如下配置可以启动了,但是现象比较奇怪
```
app.conf.task_queues = (Broadcast('broadcast_tasks'),)
app.conf.task_routes = {
'celery_task.method.get_new_method': {
'queue': 'broadcast_tasks',
'exchange': 'broadcast_tasks'
}
}
```
从 rabbitmq 控制台上面能够看到信息被推进了 broadcast 信道,但是无法被消费
hustlibraco
2019-08-26 17:33:30 +08:00
@ray1888 我也遇到无法被消费的问题,请问解决了吗

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/468878

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX