[JMS 3] ActiveMQ實現簡單的helloworld

目錄(?)[-]html

  1. 開發環境java

  2. 搭建開發環境apache

  3. 運行編程

  4. 總結api

第一篇博文深刻淺出JMS(一)–JMS基本概念,咱們介紹了JMS的兩種消息模型:點對點和發佈訂閱模型,以及消息被消費的兩個方式:同步和異步,JMS編程模型的對象,最後說了JMS的優勢。瀏覽器

第二篇博文深刻淺出JMS(二)–ActiveMQ簡單介紹以及安裝,咱們介紹了消息中間件ActiveMQ,安裝,啓動,以及優缺點。服務器

這篇博文,咱們使用ActiveMQ爲你們實現一種點對點的消息模型。若是你對點對點模型的認識較淺,能夠看一下第一篇博文的介紹。session

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

開發環境

咱們使用的是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);
        }

    }
}123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  • 編寫消費者

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

    }
}1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465

運行

  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整合的實例。

源碼下載

相關文章
相關標籤/搜索