ActiveMQ支持的client-broker通訊協議有:TCP、NIO、UDP、SSL、Http(s)、VM。 其中配置Transport Connector的文件在activeMQ安裝目錄的conf/activemq.xml中的 ...
本文使用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集群部署時。