1. 程式人生 > >深入淺出JMS(三)--ActiveMQ簡單的HelloWorld例項

深入淺出JMS(三)--ActiveMQ簡單的HelloWorld例項

第一篇博文深入淺出JMS(一)–JMS基本概念,我們介紹了JMS的兩種訊息模型:點對點和釋出訂閱模型,以及訊息被消費的兩個方式:同步和非同步,JMS程式設計模型的物件,最後說了JMS的優點。

這篇博文,我們使用ActiveMQ為大家實現一種點對點的訊息模型。如果你對點對點模型的認識較淺,可以看一下第一篇博文的介紹。

JMS其實並沒有想象的那麼高大上,看完這篇博文之後,你就知道什麼叫簡單,下面直接進入主題。

開發環境

我們使用的是ActiveMQ 5.11.1 Release的Windows版,官網最新版是ActiveMQ 5.12.0 Release,大家可以自行下載,下載地址

需要注意的是,開發時候,要將apache-activemq-5.11.1-bin.zip解壓縮后里面的activemq-all-5.11.1.jar包加入到classpath下面,這個包包含了所有jms介面api的實現。

搭建開發環境

  • 建立專案
    我們只需要建立一個java專案就可以了,匯入jar包,專案截圖:
    這裡寫圖片描述

點對點的訊息模型,只需要一個訊息生成者和訊息消費者,下面我們編寫程式碼。

  • 編寫生產者

package com.tgb.activemq;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import
javax.jms.Destination; import javax.jms.JMSException; import javax.jms.MessageProducer; import javax.jms.Session; import javax.jms.TextMessage; import org.apache.activemq.ActiveMQConnection; import org.apache.activemq.ActiveMQConnectionFactory; /** * 訊息的生產者(傳送者) * @author liang * */ public class
JMSProducer {
//預設連線使用者名稱 private static final String USERNAME = ActiveMQConnection.DEFAULT_USER; //預設連線密碼 private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD; //預設連線地址 private static final String BROKEURL = ActiveMQConnection.DEFAULT_BROKER_URL; //傳送的訊息數量 private static final int SENDNUM = 10; public static void main(String[] args) { //連線工廠 ConnectionFactory connectionFactory; //連線 Connection connection = null; //會話 接受或者傳送訊息的執行緒 Session session; //訊息的目的地 Destination destination; //訊息生產者 MessageProducer messageProducer; //例項化連線工廠 connectionFactory = new ActiveMQConnectionFactory(JMSProducer.USERNAME, JMSProducer.PASSWORD, JMSProducer.BROKEURL); try { //通過連線工廠獲取連線 connection = connectionFactory.createConnection(); //啟動連線 connection.start(); //建立session session = connection.createSession(true, Session.AUTO_ACKNOWLEDGE); //建立一個名稱為HelloWorld的訊息佇列 destination = session.createQueue("HelloWorld"); //建立訊息生產者 messageProducer = session.createProducer(destination); //傳送訊息 sendMessage(session, messageProducer); session.commit(); } catch (Exception e) { e.printStackTrace(); }finally{ if(connection != null){ try { connection.close(); } catch (JMSException e) { e.printStackTrace(); } } } } /** * 傳送訊息 * @param session * @param messageProducer 訊息生產者 * @throws Exception */ public static void sendMessage(Session session,MessageProducer messageProducer) throws Exception{ for (int i = 0; i < JMSProducer.SENDNUM; i++) { //建立一條文字訊息 TextMessage message = session.createTextMessage("ActiveMQ 傳送訊息" +i); System.out.println("傳送訊息:Activemq 傳送訊息" + i); //通過訊息生產者發出訊息 messageProducer.send(message); } } }
  • 編寫消費者

package com.tgb.activemq;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.MessageConsumer;
import javax.jms.Session;
import javax.jms.TextMessage;

import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
/**
 * 訊息的消費者(接受者)
 * @author liang
 *
 */
public class JMSConsumer {

    private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;//預設連線使用者名稱
    private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;//預設連線密碼
    private static final String BROKEURL = ActiveMQConnection.DEFAULT_BROKER_URL;//預設連線地址

    public static void main(String[] args) {
        ConnectionFactory connectionFactory;//連線工廠
        Connection connection = null;//連線

        Session session;//會話 接受或者傳送訊息的執行緒
        Destination destination;//訊息的目的地

        MessageConsumer messageConsumer;//訊息的消費者

        //例項化連線工廠
        connectionFactory = new ActiveMQConnectionFactory(JMSConsumer.USERNAME, JMSConsumer.PASSWORD, JMSConsumer.BROKEURL);

        try {
            //通過連線工廠獲取連線
            connection = connectionFactory.createConnection();
            //啟動連線
            connection.start();
            //建立session
            session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
            //建立一個連線HelloWorld的訊息佇列
            destination = session.createQueue("HelloWorld");
            //建立訊息消費者
            messageConsumer = session.createConsumer(destination);

            while (true) {
                TextMessage textMessage = (TextMessage) messageConsumer.receive(100000);
                if(textMessage != null){
                    System.out.println("收到的訊息:" + textMessage.getText());
                }else {
                    break;
                }
            }

        } catch (JMSException e) {
            e.printStackTrace();
        }

    }
}

執行

  1. 首先,啟動ActiveMQ,如何啟動ActiveMQ如何啟動,請看第二篇博文。在瀏覽器中輸入:http://localhost:8161/admin/,然後開始執行:
  2. 執行傳送者,eclipse控制檯輸出,如下圖:
    這裡寫圖片描述
    此時,我們先看一下ActiveMQ伺服器,Queues內容如下:
    這裡寫圖片描述
    我們可以看到建立了一個名稱為HelloWorld的訊息佇列,佇列中有10條訊息未被消費,我們也可以通過Browse檢視是哪些訊息,如下圖:
    這裡寫圖片描述
    如果這些佇列中的訊息,被刪除,消費者則無法消費。

  3. 我們繼續執行一下消費者,eclipse控制檯列印訊息,如下:
    這裡寫圖片描述
    此時,我們先看一下ActiveMQ伺服器,Queues內容如下:
    這裡寫圖片描述
    我們可以看到HelloWorld的訊息佇列發生變化,多一個訊息者,佇列中的10條訊息被消費了,點選Browse檢視,已經為空了。
    點選Active Consumers,我們可以看到這個消費者的詳細資訊:
    這裡寫圖片描述

我們的例項到此就結束了,大家可以自己多點ActiveMQ伺服器的內容,進一步熟悉ActiveMQ。

總結

這篇博文我們實現了點對點的訊息模型以及傳送的一個同步訊息,是不是非常的簡單?

下面博文,我們將實現一個ActiveMQ和Spring整合的例項。

原始碼下載