ActiveMQ多个消费者监听一个列队,最后是谁消费了?

看过消息队列资料的同学应该在网上都看到过这段代码:
//创建一个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的话,无法确定一个消息最终会被哪一个消费者消费(可以搜索这句话便可找到很多博文都是这么写)。

你可能感兴趣的:(JAVA)