Work queues
java代码如何实现
第一步 应该在rabbitmq控制台上创建队列
第二步 然后创建MqWorkTest 生命这是消费者,并且有2个消费者
第三部 创建发送者SpringAmqpWorkTest类 这是发送者
相当于循环发送50次消息
启动之后是这样的
这样不好看出来我们可以这样
System.err.println("消费者1收到消息:"+mes);
System.out.println("消费这2收到消息:"+mes);
消费者1是err 消费者2用黑色
这种只是好区分没有其他意思
结论
1 :”第一个消费者和第二个消费者总和是队列中消息的总和
相当于第一个消费者消费玩消息后,第二个消费者不能再次消费第一个消费者消费的消息
2 :当我们像队列投递很多消息,并且有很多消费者监听这个队列时,会有一种轮询的机制
像这种情况是有问题,如果2个消费者的消费能力不一样,还会出来一样的结果吗?
从 RabbitMQ 3.8 版本开始,广播模式(fanout exchange)默认使用基于性能的接收模式(performant mode)而不是轮询模式(round-robin mode)。
在轮询模式中,每个消费者会按照顺序接收到消息,即使其中有些消费者的处理能力强于其他消 费者。这可能导致消息在某些消费者上积压,而其他消费者没有得到充分利用。
而在基于性能的接收模式中,RabbitMQ 会尽量将消息发送给处理能力较强的消费者,以实现更 好 的负载均衡和性能利用。这种模式可以让消息更快地被处理,提高整体系统的吞吐量。
3