Terry.Li-彬

          虛其心,可解天下之問;專其心,可治天下之學;靜其心,可悟天下之理;恒其心,可成天下之業。

            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
            143 隨筆 :: 344 文章 :: 130 評論 :: 0 Trackbacks

          簡介

          上一篇http://www.javaeye.com/topic/15317介紹了ActiveMQ5.0的安裝,這一篇將介紹的配置。ActiveMQ包含了很多features(詳見http://activemq.apache.org/features.html ),  
          不同的需求,不同的環境,需要不同的features,當然需要不同的配置。在這里我只寫了最基本的配置,算是拋磚了,希望引出更多關于ActiveMQ的高級配置。
          假設已經正確安裝ActiveMQ5.0,同時及其IP地址為192.168.1.148,具體使用時可以改為自己的IP。下面講解的配置實現的features如下:

          1. 客戶端可以通過tcp://192.168.1.148連接ActiveMQ。
          2. 消息持久化保存,重啟服務器不會丟失消息。
          3. 可以通過http://192.168.1.148:8161/admin監控ActiveMQ服務器

          配置

          ActiveMQ默認使用的是XML格式配置,從4.0版本開始用MBean的方式實現XML配置,配置文件在${activemq.home}/conf目錄下,文件名為activemq.xml。最新的默認配置見
          http://svn.apache.org/repos/asf/activemq/trunk/assembly/src/release/conf/activemq.xml 。下面為本篇文章使用的配置,及重要部分的解釋。

           

          Xml代碼 復制代碼
          1. <beans  
          2.   xmlns="http://www.springframework.org/schema/beans"  
          3.   xmlns:amq="http://activemq.org/config/1.0"  
          4.   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd   
          5.   http://activemq.org/config/1.0 http://activemq.apache.org/schema/activemq-core.xsd   
          6.   http://activemq.apache.org/camel/schema/spring>  
          7.     
          8.   <!-- persistent="true"表示要持久化存儲消息,和子元素persistenceAdapter結合使用 -->  
          9.   <!-- dataDirectory默認的存儲持久化數據的目錄 -->  
          10.   <!-- brokerName 設置broker的name,在注意在網絡上必須是唯一的-->  
          11.   <!-- 更多參考http://activemq.apache.org/xbean-xml-reference-50.html#XBeanXMLReference5.0-brokerelement -->  
          12.   <broker xmlns="http://activemq.org/config/1.0" brokerName="192.168.1.148" persistent ="true" dataDirectory="${activemq.base}/data" useShutdownHook="false">  
          13.     
          14.     <!-- Destination specific policies using destination names or wildcards -->  
          15.     <!-- wildcards意義見http://activemq.apache.org/wildcards.html -->  
          16.     <destinationPolicy>  
          17.       <policyMap>  
          18.         <policyEntries>  
          19.        <!-- 這里使用了wildcards,表示所有以EUCITA開頭的topic -->  
          20.           <policyEntry topic="EUCITA.>" producerFlowControl="false" memoryLimit="10mb">  
          21.             <!-- 分發策略 -->  
          22.         <dispatchPolicy>  
          23.           <!-- 按順序分發 -->  
          24.               <strictOrderDispatchPolicy/>  
          25.             </dispatchPolicy>  
          26.         <!--  恢復策略-->  
          27.             <subscriptionRecoveryPolicy>  
          28.           <!-- 只恢復最后一個message -->  
          29.               <lastImageSubscriptionRecoveryPolicy/>  
          30.             </subscriptionRecoveryPolicy>  
          31.           </policyEntry>  
          32.         </policyEntries>  
          33.       </policyMap>  
          34.     </destinationPolicy>  
          35.   
          36.     <!-- The transport connectors ActiveMQ will listen to -->  
          37.     <transportConnectors>  
          38.        <transportConnector name="openwire" uri="tcp://192.168.1.148:61616" discoveryUri="multicast://default"/>  
          39.        <transportConnector name="ssl"     uri="ssl://192.168.1.148:61617"/>  
          40.        <transportConnector name="stomp"   uri="stomp://192.168.1.148:61613"/>  
          41.        <transportConnector name="xmpp"    uri="xmpp://192.168.1.148:61222"/>  
          42.     </transportConnectors>  
          43.       
          44.     <!-- 消息持久化方式 -->  
          45.     <persistenceAdapter>  
          46.       <amqPersistenceAdapter directory="${activemq.base}/data"/>  
          47.     </persistenceAdapter>  
          48. </broker>  
          49.   
          50.   <!-- lets create a command agent to respond to message based admin commands on the ActiveMQ.Agent topic -->  
          51.     <commandAgent xmlns="http://activemq.org/config/1.0"/>  
          52.      
          53.   <!-- An embedded servlet engine for serving up the Admin console -->  
          54.   <jetty xmlns="http://mortbay.com/schemas/jetty/1.0">  
          55.     <connectors>  
          56.       <nioConnector port="8161" />  
          57.     </connectors>  
          58.   
          59.     <handlers>  
          60.       <webAppContext contextPath="/admin" resourceBase="${activemq.base}/webapps/admin" logUrlOnStart="true" />        
          61.       <webAppContext contextPath="/demo" resourceBase="${activemq.base}/webapps/demo" logUrlOnStart="true" />          
          62.     </handlers>  
          63.   </jetty>    
          64. </beans>  

          注釋

          關于XML配置中元素的具體信息可以參考http://activemq.apache.org/xbean-xml-reference-50.html 下面介紹本篇配置使用的一些重要元素。

          DispathPolicy

          ActiveMQ支持3中不同的分發策略(避免翻譯了以后誤解,這里用原文):

          1. <roundRobinDispatchPolicy>:Simple dispatch policy that sends a message to every subscription that matches the message.
          2. <simpleDispatchPolicy>:Simple dispatch policy that sends a message to every subscription that matches the message.
          3. <strictOrderDispatchPolicy>:Dispatch policy that causes every subscription to see messages in the same order.

          SubscriptionRecoveryPolicy

          ActiveMQ支持6種恢復策略,可以自行選擇使用不同的策略

          1. <fixedCountSubscriptionRecoveryPolicy>: keep a fixed count of last messages.
          2. <fixedSizedSubscriptionRecoveryPolicy>: keep a fixed amount of memory available in RAM for message history which is evicted in time order.
          3. <lastImageSubscriptionRecoveryPolicy>:only keep the last message.
          4. <noSubscriptionRecoveryPolicy>:disable recovery of messages.
          5. <queryBasedSubscriptionRecoveryPolicy>:perform a user specific query mechanism to load any messages they may have missed.
          6. <timedSubscriptionRecoveryPolicy>:keep a timed buffer of messages around in memory and use that to recover new subscriptions.

          PersistenceAdapter

          http://activemq.apache.org/persistence 講解了關于persistence的信息。ActiveMQ5.0使用AMQ Message Store 持久化消息,這種方式提供了很好的性能(The AMQ Message Store is an embeddable transactional message storage solution that is extremely fast and reliable.) 默認使用該存儲方式即可,如果想使用JDBC來存儲,可以查找文檔配置。 

          Summary

          本篇文章只提供了基本配置信息。如果需要更多的文章,可以查看ActiveMQ的文檔。

          講了安裝和簡單的配置,下一篇將介紹和Sping的整合,以及多個queue,多個topic,多個producer,多個consumer的配置,使用。

          posted on 2008-12-31 22:09 禮物 閱讀(2344) 評論(0)  編輯  收藏 所屬分類: JMS
          主站蜘蛛池模板: 莎车县| 庆城县| 凌海市| 罗田县| 盱眙县| 万宁市| 昭觉县| 江津市| 同江市| 平顶山市| 泰和县| 新建县| 平和县| 古蔺县| 雅江县| 遵义市| 固始县| 平阴县| 吉安县| 秦皇岛市| 太谷县| 大庆市| 栖霞市| 安阳县| 东乌珠穆沁旗| 普洱| 攀枝花市| 永春县| 吉木萨尔县| 青河县| 昭平县| 金塔县| 吉林省| 沙洋县| 榆林市| 金昌市| 巴楚县| 贵德县| 延边| 西吉县| 姚安县|