厚積而薄發

          山不辭土,故能成其高;海不辭水,故能成其深!
          posts - 15, comments - 0, trackbacks - 0, articles - 1

          深入掌握JMS(二):一個JMS例子

          Posted on 2009-10-22 19:53 Robin 閱讀(1238) 評論(0)  編輯  收藏
          轉http://hi.baidu.com/yonered/blog/item/a38d77188dbc9e0f34fa412d.html

          前一講簡單的介紹了一下JMS的基本概念, 這一講結合一個例子讓大家深入理解前一講的基本概念. 首先需要做的是選擇一個JMS提供者, 如果在JavaEE環境中可以不用考慮這些. 我們選擇ActiveMQ, 官方地址: http://activemq.apache.org/. 網上有很多介紹ActiveMQ的文檔, 所以在這里就不介紹了.

          按照上一講的這個簡圖,

          ConnectionFactory---->Connection--->Session--->Message
          Destination + Session------------------------------------>Producer
          Destination + Session------------------------------------>MessageConsumer

          首先需要得到ConnectionFactoy和Destination,這里創建一個一對一的Queue作為Destination。
          ConnectionFactory factory = new ActiveMQConnectionFactory("vm://localhost");
          Queue queue = new ActiveMQQueue("testQueue");

          然后又ConnectionFactory創建一個Connection, 再啟動這個Connection:
          Connection connection = factory.createConnection();
          connection.start();

          接下來需要由Connection創建一個Session:
          Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE)
              現在暫且不用管參數的含義, 以后會詳細講到.

          下面就可以創建Message了,這里創建一個TextMessage。
          Message message = session.createTextMessage("Hello JMS!");

          要想把剛才創建的消息發送出去,需要由Session和Destination創建一個消息生產者:
          MessageProducer producer = session.createProducer(queue);

          下面就可以發送剛才創建的消息了:
          producer.send(message);

          消息發送完成之后,我們需要創建一個消息消費者來接收這個消息:
          MessageConsumer comsumer = session.createConsumer(queue);
          Message recvMessage = comsumer.receive();

          消息消費者接收到這個消息之后,就可以得到它的內容:
          System.out.println(((TextMessage)recvMessage).getText());

          至此,一個簡單的JMS例子就完成了。下面是全部源碼

          import javax.jms.Connection;
          import javax.jms.Message;
          import javax.jms.MessageConsumer;
          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 {

              public static void main(String[] args) throws Exception {
                  ConnectionFactory factory = new ActiveMQConnectionFactory("vm://localhost");
             
                  Connection connection = factory.createConnection();
                  connection.start();
                 
                  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);
                  Message recvMessage = comsumer.receive();
                  System.out.println(((TextMessage)recvMessage).getText());
              }

          }


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 大埔区| 河西区| 蓬溪县| 濉溪县| 五莲县| 边坝县| 开远市| 长子县| 平顶山市| 青铜峡市| 望江县| 江源县| 肇东市| 同江市| 葫芦岛市| 三门峡市| 光泽县| 望都县| 陵水| 陇西县| 桂阳县| 南安市| 乌兰县| 凤台县| 洱源县| 萍乡市| 蓬溪县| 二手房| 余干县| 谢通门县| 衢州市| 镇康县| 汉中市| 武安市| 临沂市| 嘉禾县| 湟中县| 左贡县| 通渭县| 汉中市| 镶黄旗|