JMS 之 Active MQ 的消息傳輸

来源:http://www.cnblogs.com/jalja/archive/2017/06/18/6937354.html
-Advertisement-
Play Games

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集群部署時。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Dictionary list=new Dictionary; foreach(var item in list) { Console.WriteLine(item.Key+item.Value); } //KeyValuePair foreach(KeyValuePair kv in list) ... ...
  • 1).獲取緩存值 object o = HttpRuntime.Cache.Get("Key"); 2).設置相對過期緩存值有兩種寫法 第一種: HttpRuntime.Cache.Insert("Key", "Value", null, System.Web.Caching.Cache.NoAbs... ...
  • 代碼: private string GetImageExtension(MemoryStream ms) { try { Image image = Image.FromStream(ms); if (image.RawFormat.Guid == ImageFormat.Bmp.Guid) re ...
  • 版權聲明:本文為原創文章,轉載請聲明http://www.cnblogs.com/unityExplorer/p/7027659.html 上篇已經把socket的傳輸說的差不多了,這篇主要是說說斷線重連,沒什麼好說的,直接上代碼吧 ...
  • 遇到一個奇怪的問題 ,只然訪問到Index的action,訪問其它的都報404錯 ,在Windows的IIS上則不會有此問題 如 正常 http://localhost:5000/login/index 報404錯誤 http://localhost:5000/login/test 經查是Start ...
  • 要求是這樣子的,在一個列表頁中,用戶點擊詳細銨鈕,帶記錄的主鍵值至另一頁。在另一外頁中,獲取記錄數據,然後顯示此記錄數據在網頁上。先用動圖演示: 昨天有分享為ng-click傳遞參數 《angularjs為ng-click事件傳遞參數》http://www.cnblogs.com/insus/p/7 ...
  • Java中的wait/notify/notifyAll可用來實現線程間通信,是Object類的方法,這三個方法都是native方法,是平臺相關的,常用來實現生產者/消費者模式。先來我們來看下相關定義: wait() :調用該方法的線程進入WATTING狀態,只有等待另外線程的通知或中斷才會返回,調用 ...
  • 第九節 函數 函數就是完成特定功能的一個語句組,這組語句可以作為一個單位使用,並且給它取一個名字。 可以通過函數名在程式的不同地方多次執行(這通常叫做函數調用),卻不需要在所有地方都重覆編寫這些語句。 自定義函數 用戶自己編寫的 預定義的Python函數 系統自帶的一些函數,還有一些和第三方編寫的函 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...