<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                企業??AI智能體構建引擎,智能編排和調試,一鍵部署,支持知識庫和私有化部署方案 廣告
                [深入淺出JMS(三)--ActiveMQ簡單的HelloWorld實例](http://blog.csdn.net/jiuqiyuliang/article/details/48608237) [TOC] 第一篇博文[深入淺出JMS(一)–JMS基本概念](http://blog.csdn.net/jiuqiyuliang/article/details/46701559),我們介紹了JMS的兩種消息模型:點對點和發布訂閱模型,以及消息被消費的兩個方式:同步和異步,JMS編程模型的對象,最后說了JMS的優點。 第二篇博文[深入淺出JMS(二)–ActiveMQ簡單介紹以及安裝](http://blog.csdn.net/jiuqiyuliang/article/details/47160259),我們介紹了消息中間件ActiveMQ,安裝,啟動,以及優缺點。 這篇博文,我們使用ActiveMQ為大家實現一種點對點的消息模型。如果你對點對點模型的認識較淺,可以看一下第一篇博文的介紹。 JMS其實并沒有想象的那么高大上,看完這篇博文之后,你就知道什么叫簡單,下面直接進入主題。 ### 開發環境 我們使用的是ActiveMQ 5.11.1 Release的Windows版,官網最新版是ActiveMQ 5.12.0 Release,大家可以自行下載,[下載地址](http://activemq.apache.org/download-archives.html)。 需要注意的是,開發時候,要將apache-activemq-5.11.1-bin.zip解壓縮后里面的activemq-all-5.11.1.jar包加入到classpath下面,這個包包含了所有jms接口api的實現。 ### 搭建開發環境 * 建立項目? 我們只需要建立一個java項目就可以了,導入jar包,項目截圖:? ![這里寫圖片描述](http://img.blog.csdn.net/20150920171843767) 點對點的消息模型,只需要一個消息生成者和消息消費者,下面我們編寫代碼。 * 編寫生產者 ~~~ 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/](http://localhost:8161/admin/),然后開始執行: 2. 運行發送者,eclipse控制臺輸出,如下圖:? ![這里寫圖片描述](http://img.blog.csdn.net/20150920173405956)? 此時,我們先看一下ActiveMQ服務器,Queues內容如下:? ![這里寫圖片描述](http://img.blog.csdn.net/20150920173620033) 我們可以看到創建了一個名稱為HelloWorld的消息隊列,隊列中有10條消息未被消費,我們也可以通過Browse查看是哪些消息,如下圖:? ![這里寫圖片描述](http://img.blog.csdn.net/20150920174135335) 如果這些隊列中的消息,被刪除,消費者則無法消費。 3. 我們繼續運行一下消費者,eclipse控制臺打印消息,如下:? ![這里寫圖片描述](http://img.blog.csdn.net/20150920174317150)? 此時,我們先看一下ActiveMQ服務器,Queues內容如下:? ![這里寫圖片描述](http://img.blog.csdn.net/20150920174417511) 我們可以看到HelloWorld的消息隊列發生變化,多一個消息者,隊列中的10條消息被消費了,點擊Browse查看,已經為空了。? 點擊Active Consumers,我們可以看到這個消費者的詳細信息:? ![這里寫圖片描述](http://img.blog.csdn.net/20150920175100179) 我們的實例到此就結束了,大家可以自己多點ActiveMQ服務器的內容,進一步熟悉ActiveMQ。 ### 總結 這篇博文我們實現了點對點的消息模型以及發送的一個同步消息,是不是非常的簡單? 下面博文,我們將實現一個ActiveMQ和[spring](http://lib.csdn.net/base/javaee "Java EE知識庫")整合的實例。 [源碼下載](http://download.csdn.net/detail/jiuqiyuliang/9122251)
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看