本文使用Active MQ5.6
transportConnectors 連接器:就是建立broker與訊息生產者、訊息消費者之間的互動。
傳輸連接器常用的協定:在Active MQ中常用的連線協定:tcp、udp、nio、ssl、http、 https、vm。如果使用ssl協定需要設定證書,使用http或https需要使用httpclient來傳送接收訊息。
使用TCP協定的好處
高效的:該協定連接使用了OpenWire協定,透過把訊息轉換成字節流,效能非常好
可用性:TCP是使用非常廣泛的網路協議,基本上所有的平台都支援TCP設定範例conf/activemq.xml :
<transportConnectors><!--activemq 的默认连接 tcp--><transportConnector name="openwire" uri="tcp://0.0.0.0:61616"/></transportConnectors>
可能有大量的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只是一個連結協議,所以它沒有可靠性之說
# b、UDP連線的URI形式:udp://hostname:port?key=value c、設定實例 conf/activemq.xml
<transportConnectors><transportConnector name="udp" uri="udp://localhost:61618"/></transportConnectors>
(4)、SSL
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>
以上是JMS 之 Active MQ 的訊息傳輸的詳細內容。更多資訊請關注PHP中文網其他相關文章!