RabbitMQ怎样能实现多个队列由一个消费者来接收消息

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了RabbitMQ怎样能实现多个队列由一个消费者来接收消息相关的知识,希望对你有一定的参考价值。

1、笨拙点方法,就是轮循,consume的阻塞监听可以设置timeout,通过设置一个较小的timeout,可以轮流监听几个channel,变相实现监听多个queue,对性能要求不是很高,可以使用这种方法
2、还有个办法就是先取出一个队列的消息数,然后循环的都读出后,转去读另一个队列,所有队列如果都没有消息了,就这样循环等待着
3、还有一个专业人士的回答,但是我还没有完全理解:
消费者(consumer)这是个业务层的概念,而消费或者说订阅(也就是 consume)是 AMQP 协议层的东西,所以,你问一个消费者能否订阅多个queue,答案是当然可以。方案也就一种,按照协议的流程分别向不同的 queue 进行 consume。至于是使用多线程方式来处理,还是使用事件驱动的方式(单线程)来处理这就取决于实现了。
如果对多线程控制能力不是很强,建议不要用这种方式,太专业了
4、这个问题后来我仔细想过,也许可以在应用层进行一下重新设计,可以用线程池作为多个consumer只读取出消息,不进行处理,然后publish进另一个队列,然后用由一个consumer来处理消息
参考技术A

    创建多个队列

    消费者创建同等个数的channel同时绑定到消息队列上

    使用消息模式处理各个通道上的消息

关键在于一个消费者创建N个channel绑定,实现多个通道消息的异步处理

以上是关于RabbitMQ怎样能实现多个队列由一个消费者来接收消息的主要内容,如果未能解决你的问题,请参考以下文章

RabbitMQ中有大批量的消息,此时多个消费者同时访问消息队列是怎样取里面的消息的?

rabbitmq消息队列介绍

RabbitMQ 跨多个队列的多个消费者 - 消息延迟处理

rabbitMQ 点对点 一个队列可以多个消费者吗?

rabbitMQ的第三种模型(fanout)

rabbitMQ的第三种模型(fanout)