您的位置:首页 > 其它

JMS&MQ,从入门到精通(五)

2017-04-28 12:06 330 查看
上篇我们介绍了,jms实现消息持久化的案例,本篇我们来介绍一个稍微复杂的场景


场景介绍

创建两个Queue,发送者给一个Queue发送,接收者接收到消息之后给另一个Queue回复一个Message,前一个发送者进行接受处理


实现思路

1.创建一个连接
2.创建两个queue,sendQueue,replyQueue
3.给队列sendQueue发消息,监听这处理从replyQueue回复消息给发送者


一个简单的实例

ActiveMQConnectionFactory factory = new ActiveMQConnectionFactory("vm://localhost");
Connection connection = factory.createConnection();
connection.start();

//消息发送到这个Queue
Queue queue = new ActiveMQQueue("sendQueue");

//消息回复到这个Queue
Queue replyQueue = new ActiveMQQueue("replyQueue");

final Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);

//创建一个消息,并设置它的JMSReplyTo为replyQueue。
Message message = session.createTextMessage("Andy");
message.setJMSReplyTo(replyQueue);

MessageProducer producer = session.createProducer(queue);
producer.send(message);
System.out.println("send message Andy  finish....");

//消息的接收者
MessageConsumer comsumer = session.createConsumer(queue);
comsumer.setMessageListener(new MessageListener(){
public void onMessage(Message m) {
try {
//创建一个新的MessageProducer来发送一个回复消息。
MessageProducer producer = session.createProducer(m.getJMSReplyTo());
producer.send(session.createTextMessage("Hello " + ((TextMessage) m).getText()));
System.out.println("producer 接收到消息后,回复消息完毕");
} catch (JMSException e1) {
e1.printStackTrace();
}
}

});

//这个接收者用来接收回复的消息
MessageConsumer comsumer2 = session.createConsumer(replyQueue);
comsumer2.setMessageListener(new MessageListener(){
public void onMessage(Message m) {
try {
System.out.println("接受到producer回复的消息:"+((TextMessage) m).getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
});
//首先消息生产者发送一个消息,内容为“Andy”, 然后消费者收到这个消息之后根据消息的JMSReplyTo,
// 回复一个消息,内容为“Hello Andy‘。 最后在回复的Queue上创建一个接收回复消息的消费者,它输出所回复的内容。


我们来看一下运行结果:




下一篇我们介绍一下,Queue的一些细节
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: