看过消息队列资料的同学应该在网上都看到过这段代码: //创建一个Queue Queue queue = new ActiveMQQueue("testQueue"); Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); //注册消费者1 MessageConsumer comsumer1 = session.createConsumer(queue); comsumer1.setMessageListener(new MessageListener(){ public void onMessage(Message m) { System.out.println("Consumer1 get " + ((TextMessage)m).getText()); } }); //注册消费者2 MessageConsumer comsumer2 = session.createConsumer(queue); comsumer2.setMessageListener(new MessageListener(){ public void onMessage(Message m) { System.out.println("Consumer2 get " + ((TextMessage)m).getText()); } }); //创建一个生产者,然后发送多个消息。 MessageProducer producer = session.createProducer(queue); for(int i=0; i<10; i++){ producer.send(session.createTextMessage("Message:" + i)); } } 运行结果: Consumer1 get Message:0 Consumer2 get Message:1 Consumer1 get Message:2 结论:可以看出每个消息直被消费了一次,但是如果有多个消费者同时监听一个Queue的话,无法确定一个消息最终会被哪一个消费者消费(可以搜索这句话便可找到很多博文都是这么写)。
ActiveMQ多个消费者监听一个列队,最后是谁消费了?
最新推荐文章于 2020-12-24 16:48:56 发布