您的位置:首页 > 其它

JMS入门及简单例子

2017-01-14 18:52 274 查看
参考:http://blog.csdn.net/wl_ldy/article/category/1216997

基本概念

JMS(Java Message Service)即java消息服务。它提供了标准的生产、发送和接收信息的借口,简化了企业开发的流程。它提供了两种方式的消息通信模型:点对点的模型、发布/点阅模型。

重要的几个概念:

Destination:消息发送的目的地

Message:被发送的消息,它包括数据流、map和普通text等类型。

Session:信息生成者与消息服务JMS建立的会话,只能通过session创建Message。

Connection:信息生产者与消息服务JMS建立的连接,通过它创建Session。

ConnectionFactory:连接工厂。

Producer:消息生产者。

MessageConsumer:消息的消费者。

下面是一个基于ActiveMQ消息服务器的例子

/**
* @author Administrator
* @desctiption 结合一个例子,深入理解JMS的基本概念
* 消息的消费者接收消息可以采用两种方式:
* 1、consumer.receive() 或 consumer.receive(int timeout);
* 2、注册一个MessageListener。
* 采用第一种方式,消息的接收者会一直等待下去,直到有消息到达,或者超时。
* 后一种方式会注册一个监听器,当有消息到达的时候,会回调它的onMessage()方法。
*/
package com.wl.jms;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageListener;
import javax.jms.MessageProducer;
import javax.jms.Queue;
import javax.jms.Session;
import javax.jms.TextMessage;

import org.apache.activemq.ActiveMQConnectionFactory;
import org.apache.activemq.command.ActiveMQQueue;

public class MessageSendAndReceive {

/**
* @param args
* @throws JMSException
*/
public static void main(String[] args) throws JMSException {
// TODO Auto-generated method stub
ConnectionFactory factory = new ActiveMQConnectionFactory("vm://localhost");

Connection connection = factory.createConnection();
connection.start();
//创建消息的Destination
Queue queue = new ActiveMQQueue("testQueue");

final Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//创建将要发送的消息
Message message = session.createTextMessage("Hello JMS!");
//创建消息生产者发送消息
MessageProducer producer = session.createProducer(queue);
producer.send(message);

System.out.println("Send Message Completed!");
//创建消息的接收者
MessageConsumer comsumer = session.createConsumer(queue);
//消息的消费者接收消息的第一种方式:consumer.receive() 或 consumer.receive(int timeout);
//Message recvMessage = comsumer.receive();
//System.out.println(((TextMessage)recvMessage).getText());
//消息的消费者接收消息的第二种方式:注册一个MessageListener
comsumer.setMessageListener(new MessageListener(){
public void onMessage(Message msg) {
// TODO Auto-generated method stub
TextMessage textMsg=(TextMessage)msg;
try {
System.out.println(textMsg.getText());
} catch (JMSException e) {
e.printStackTrace();
}
}

});
}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  jms ActiveMQ