JMS 之 Active MQ 的消息傳輸


本文使用Active MQ5.6 

一、消息協商器(Message Broker)

broke:消息的交換器,就是對消息進行管理的容器。ActiveMQ 可以創建多個 Broker,客戶端與ActiveMQ交互,實際上都是與ActiveMQ中的Broker交互,Broker配置在${MQ_HOME}\conf\activemq.xml。

 

二、連接器(Connectors)

(一)、傳輸連接器 (transportConnectors)

transportConnectors 連接器:就是建立broker與消息生產者、消息消費者之間的交互。

傳輸連接器常用的協議:

  在Active MQ中常用的連接協議:tcp、udp、nio、ssl、http、https、vm。如果使用ssl協議需要配置證書,使用http或者https需要使用httpclient來發送接收消息。

(1)TCP默認的協議

tcp://hostname:port?key=value&key=value   后面的參數選填
使用TCP協議的好處

  • 高效的:該協議連接使用了OpenWire協議,通過把消息轉換成字節流,性能非常好
  • 可用性:TCP是使用非常廣泛的網絡協議,基本上所有的平台都支持

TCP配置示例conf/activemq.xml   :

        <transportConnectors>
            <!--activemq 的默認連接 tcp-->
            <transportConnector name="openwire" uri="tcp://0.0.0.0:61616"/>
        </transportConnectors>

(2)、NIO
a、NIO協議和TCP協議類似,但NIO更側重於底層的訪問操作。它允許開發人員對同一資源可有 更多的client調用和服務端有更多的負載。
b、適合使用NIO協議的場景:
  可能有大量的Client去鏈接到Broker上 一般情況下,大量的Client去鏈接Broker是被操作系統的線程數所限制的。因此, NIO的實現比TCP需要更少的線程去運行,所以建議使用NIO協議
  可能對於Broker有一個很遲鈍的網絡傳輸 NIO比TCP提供更好的性能
c、NIO連接的URI形式:nio://hostname:port?key=value   后面的參數選填

d、NIO配置實例 conf/activemq.xml:

         <transportConnectors>
            <!-- 設置一個NIO的連接-->
            <transportConnector name="nio" uri="nio://0.0.0.0:61617"/>
        </transportConnectors>

(3)、UDP

  a、UDP和TCP的區別

  • TCP是一個原始流的傳遞協議,意味着數據包是有保證的,換句話說,數據包是不會被復 制和丟失的。UDP,另一方面,它是不會保證數據包的傳遞的
  • TCP也是一個穩定可靠的數據包傳遞協議,意味着數據在傳遞的過程中不會被丟失。這樣 確保了在發送和接收之間能夠可靠的傳遞。相反,UDP僅僅是一個鏈接協議,所以它沒有可 靠性之說
  • TCP是被用在穩定可靠的場景中使用的;UDP通常用在快速數據傳遞和不 怕數據丟失的場景中,還有ActiveMQ通過防火牆時,只能用UDP

  b、UDP連接的URI形式:udp://hostname:port?key=value

       c、配置實例 conf/activemq.xml

        <transportConnectors>
            <transportConnector name="udp" uri="udp://localhost:61618"/>
        </transportConnectors>

(4)、SSL

底層是TCP協議,但是對傳輸數據進行了加密
a、適用場景:MQ暴露在外網,要求客戶端與broker之間通訊

b、使用步驟:
  b-1、創建SSL協議:
  b-2、配置Broker SSL協議  conf/activemq.xml:

       <sslContext>
            <sslContext keyStore="F:/beifeng/apache-activemq-5.6.0/conf/mybroker.ks"
              keyStorePassword="test123" />
       </sslContext>

  b-3、配置客戶端SSL協議:

c、SSL的連接的URI形式:ssl://hostname:port?key=value

d、配置實例 conf/activemq.xml

        <transportConnectors>
            <transportConnector name="ssl" uri="ssl://localhost:61619"/>
        </transportConnectors>

(5)HTTP、HTTPS

a、通過jetty容器來接收http協議的mq消息
b、用於只允許基本HTTP服務通過的網絡環境
c、通過httpclient來發送/接收消息,需要添加額外的java包 Httpclient、Xstream、activemq-optional
d、URI:http://hostname:port?key=value

e、配置實例conf/activemq.xml:

     <transportConnectors>
            <transportConnector name="http" uri="http://localhost:8080"/>
        </transportConnectors>

配置 HTTPS則需要在jetty.xml中配置相關證書 HTTPS= HTTP+SSL

(二、)網絡連接器(NetWorkConnectors) 

NetWorkConnectors:用於Broke與Broke之間的交互 ,主要是ActiveMq集群部署時。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM