JMs 簡單實例

1.前一講簡單的介紹了一下JMS的基本概念, 這一講結合一個例子讓大家深入理解前一講的基本概念. 首先需要做的是選擇一個JMS提供者, 如果在JavaEE環境中可以不用考慮這些. 我們選擇ActiveMQ, 官方地址: http://activemq.apache.org/. 網上有很多介紹ActiveMQ的文檔, 所以在這裏就不介紹了.
2.按照上一講的這個簡圖:
ConnectionFactory---->Connection--->Session--->Message
Destination + Session------------------------------------>Producer
Destination + Session------------------------------------>MessageConsumer
A)首先需要得到ConnectionFactoy和Destination,這裏創建一個一對一的Queue作爲Destination。
ConnectionFactory factory = new ActiveMQConnectionFactory("vm://localhost");
Queue queue = new ActiveMQQueue("testQueue");
B)然後又ConnectionFactory創建一個Connection, 再啓動這個Connection:
Connection connection = factory.createConnection();
connection.start();
C)接下來需要由Connection創建一個Session:
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE)
現在暫且不用管參數的含義, 以後會詳細講到.
D)下面就可以創建Message了,這裏創建一個TextMessage。
Message message = session.createTextMessage("Hello JMS!");
E)要想把剛纔創建的消息發送出去,需要由Session和Destination創建一個消息生產者:
MessageProducer producer = session.createProducer(queue);
F)下面就可以發送剛纔創建的消息了:
producer.send(message);
G)消息發送完成之後,我們需要創建一個消息消費者來接收這個消息:
MessageConsumer comsumer = session.createConsumer(queue);
Message recvMessage = comsumer.receive();
H)消息消費者接收到這個消息之後,就可以得到它的內容:
System.out.println(((TextMessage)recvMessage).getText());
3.至此,一個簡單的JMS例子就完成了。下面是全部源碼 :


/**
* @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();
}
}

});
}

}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章