首頁  >  文章  >  Java  >  JMS 之 Active MQ 的訊息傳輸(圖文詳解)

JMS 之 Active MQ 的訊息傳輸(圖文詳解)

怪我咯
怪我咯原創
2017-06-30 10:47:572230瀏覽

下面小編就為大家帶來一篇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叢集部署時。

以上這篇JMS 之 Active MQ 的訊息傳輸(詳解)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

以上是JMS 之 Active MQ 的訊息傳輸(圖文詳解)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn