5分鐘帶你瞭解RabbitMQ的(普通/鏡像)集群

来源:https://www.cnblogs.com/guoxiaoyu/p/18240661
-Advertisement-
Play Games

通過本文我們深入瞭解了RabbitMQ的集群模式及其優缺點。無論是普通集群還是鏡像集群,都有其適用的場景和局限性。普通集群利用Erlang語言的集群能力,但消息可靠性和高可用性方面存在一定挑戰;而鏡像集群通過主動消息同步提高了消息的可靠性和高可用性,但可能會占用大量網路帶寬。因此,在選擇集群方案時,... ...


前言

讓我們深入探討RabbitMQ的集群配置,瞭解各種集群模式的利弊。本次討論的重點是幫助您快速理解RabbitMQ集群的運作方式,以及選擇最適合您需求的模式。好的,話不多說。在RabbitMQ中,即使只有一個節點,該節點的服務也會被作為一個集群來處理。這意味著單節點系統也遵循集群架構的規範,確保一致性和可擴展性。

而多節點的集群有兩種方式:普通集群和鏡像集群(也稱主從集群)。

普通集群

這種模式充分利用了Erlang語言天生具備的集群能力。在這個集群模式中,各個節點共用相同的元數據,例如隊列結構,但消息不會冗餘存儲,而是只存在於某一個節點中。當消費者需要消費消息時,如果請求的節點並不存儲所需的數據,RabbitMQ會在節點之間臨時傳輸消息,將數據從存儲節點傳輸到消費節點。

顯然,這種集群模式存在一定的消息可靠性問題。當某個節點宕機時,該節點上的數據將無法被消費,必須等待節點恢復後才能繼續處理。這可能導致消費者端無法正確應答已經消費的消息,在服務恢復後可能導致消息被重覆消費。此外,如果消息未經持久化,重啟後消息將會丟失。

另外,這種集群模式不支持高可用性。當某個節點服務故障時,需要手動重啟該服務才能確保該節點上的消息能夠正常消費。因此,這種模式只適合一些對消息安全性要求不高的場景。在使用這種模式時,消費者應儘量連接到每一個節點,以減少消息在集群中的傳輸。

image

鏡像集群

這種模式是RabbitMQ官方HA(高可用)方案,在普通集群模式的基礎上進行了增強。在搭建普通集群之後,需要進行額外的配置和部署。其本質區別在於,這種模式會在鏡像節點之間主動進行消息同步,而不是在客戶端拉取消息時臨時同步。

在這種模式下,集群內部會通過演算法選舉產生主節點(master)和從節點(slave)。一旦主節點失效,集群將自動選舉出新的主節點,確保整個集群的高可用性。

image

優缺點

首先看下普通集群

  • 共用元數據:各節點間共用隊列結構等元數據,但缺點也很明顯消息僅存在於某一個節點
  • 消息在消費時會在節點間臨時傳輸,增加了傳輸延遲和複雜性
  • 節點宕機時,該節點上的消息無法被消費,且可能導致重覆消費,需要手動重啟宕機節點以恢復消息消費

再看下鏡像模式:

  • 主動消息同步:在鏡像節點之間主動進行消息同步,確保每個節點上都存有完整的消息數據。消息的可靠性大大提高,即使單個節點宕機,也不會導致消息丟失。但是集群內部的網路帶寬會被主動同步大量占用,可能導致網路擁塞,影響整個集群的性能。
  • 通過選舉機制,當主節點故障時,自動選出新的主節點,保證服務的連續性和可用性。

因此,並沒有一種萬能解決方案,最終還是要根據各業務需求來確定集群方案。例如,在金融交易系統或實時數據處理系統中,建議採用高可用的鏡像模式。但如果帶寬有限制且沒有實時性要求,那麼使用預設的普通集群可能更合適。

總結

通過本文我們深入瞭解了RabbitMQ的集群模式及其優缺點。無論是普通集群還是鏡像集群,都有其適用的場景和局限性。

普通集群利用Erlang語言的集群能力,但消息可靠性和高可用性方面存在一定挑戰;而鏡像集群通過主動消息同步提高了消息的可靠性和高可用性,但可能會占用大量網路帶寬。

因此,在選擇集群方案時,需要綜合考慮業務需求、系統性能和資源限制等因素。唯有根據實際情況來靈活選擇最適合的方案,以確保系統的穩定性和可靠性。


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

-Advertisement-
Play Games
更多相關文章
  • ‍ 寫在開頭 點贊 + 收藏 學會 在後臺系統中有一種常見的功能,點擊按鈕將整個網頁全屏,再點擊退出全屏。 瀏覽器提供了2種全屏方式,一種通過API在js中實現,另一種是按F11鍵進入全屏模式。 但F11進入的全屏模式優先順序更高,無法通過API退出。 基本知識 元素全屏 檢查可用 ...
  • 這篇文章介紹瞭如何運用Tailwind CSS框架創建響應式網頁設計,涵蓋博客、電商網站及企業官網的佈局實例,包括頭部導航、內容區域、側邊欄、頁腳及輪播圖等組件的響應式實現。同時,探討了與JavaScript框架集成、CSS預處理器配合、設計工具應用以及伺服器端渲染的策略,並提供了性能優化、代碼組織... ...
  • 我們是袋鼠雲數棧 UED 團隊,致力於打造優秀的一站式數據中台產品。我們始終保持工匠精神,探索前端道路,為社區積累並傳播經驗價值。 本文作者:修能 這是一段平平無奇的 SQL 語法 SELECT id, sum(name) FROM student GROUP BY id ORDER BY id; ...
  • ‍ 寫在開頭 點贊 + 收藏 學會 前言 在這之前公司項目的文檔預覽的方式都是通過微軟線上預覽服務,但是微軟的線上服務有文件大小限制,想完整使用得花錢,一些圖片文件就通過組件庫antd實現,因為我們項目存在多種類型的文件,所以為了改善用戶的體驗,決定把文件預覽單獨弄一個拆出一個項 ...
  • 這篇文章介紹了Tailwind CSS框架的特點與優勢,包括其作為實用性的CSS框架如何通過預設的樣式類實現快速佈局和設計,以及如何在不犧牲響應式和自適應性的同時減少開發時間。此外,還提及了框架的可定製性,允許開發者輕鬆創建符合項目需求的樣式規則,從而提高前端開發效率。 ...
  • Chrome 在 121 版本開始,原生支持了兩個滾動條樣式相關的樣式 scrollbar-color 和 scrollbar-width。 要知道,在此前,雖然有 ::-webkit-scrollbar 規範可以控制滾動條,可是,::-webkit-scrollbar 是非標準特性,在 MDN 文 ...
  • Spring Cloud是一個相對比較成熟的微服務框架。雖然,Spring Cloud於2016年才推出1.0的release版本, 時間最短, 但是相比Dubbo等RPC框架, Spring Cloud提供的全套的分散式系統解決方案。 Spring Cloud是一系列框架的有序集合。它利用Spri ...
  • Windows應用軟體開發,會有很多常用的模塊,比如資料庫、配置文件、日誌、後臺通信、進程通信、埋點、瀏覽器等等。下麵是目前我們公司windows梳理的部分組件,梳理出來方便大家瞭解組件概念以及依賴關係: 每個應用里,現在或者以後都可能會存在這些模塊。以我團隊開發的全家桶為例,十多個應用對後臺訪問, ...
一周排行
    -Advertisement-
    Play Games
  • 通過WPF的按鈕、文本輸入框實現了一個簡單的SpinBox數字輸入用戶組件並可以通過數據綁定數值和步長。本文中介紹了通過Xaml代碼實現自定義組件的佈局,依賴屬性的定義和使用等知識點。 ...
  • 以前,我看到一個朋友在對一個系統做初始化的時候,通過一組魔幻般的按鍵,調出來一個隱藏的系統設置界面,這個界面在常規的菜單或者工具欄是看不到的,因為它是一個後臺設置的關鍵界面,不公開,同時避免常規用戶的誤操作,它是作為一個超級管理員的入口功能,這個是很不錯的思路。其實Winform做這樣的處理也是很容... ...
  • 一:背景 1. 講故事 前些天有位朋友找到我,說他的程式每次關閉時就會自動崩潰,一直找不到原因讓我幫忙看一下怎麼回事,這位朋友應該是第二次找我了,分析了下 dump 還是挺經典的,拿出來給大家分享一下吧。 二:WinDbg 分析 1. 為什麼會崩潰 找崩潰原因比較簡單,用 !analyze -v 命 ...
  • 在一些報表模塊中,需要我們根據用戶操作的名稱,來動態根據人員姓名,更新報表的簽名圖片,也就是電子手寫簽名效果,本篇隨筆介紹一下使用FastReport報表動態更新人員簽名圖片。 ...
  • 最新內容優先發佈於個人博客:小虎技術分享站,隨後逐步搬運到博客園。 創作不易,如果覺得有用請在Github上為博主點亮一顆小星星吧! 博主開始學習編程於11年前,年少時還只會使用cin 和cout ,給單片機點點燈。那時候,類似async/await 和future/promise 模型的認知還不是 ...
  • 之前在阿裡雲ECS 99元/年的活動實例上搭建了一個測試用的MINIO服務,以前都是直接當基礎設施來使用的,這次準備自己學一下S3相容API相關的對象存儲開發,因此有了這個小工具。目前僅包含上傳功能,後續計劃開發一個類似圖床的對象存儲應用。 ...
  • 目錄簡介快速入門安裝 NuGet 包實體類User資料庫類DbFactory增刪改查InsertSelectUpdateDelete總結 簡介 NPoco 是 PetaPoco 的一個分支,具有一些額外的功能,截至現在 github 星數 839。NPoco 中文資料沒多少,我是被博客園群友推薦的, ...
  • 前言 前面使用 Admin.Core 的代碼生成器生成了通用代碼生成器的基礎模塊 分組,模板,項目,項目模型,項目欄位的基礎功能,本篇繼續完善,實現最核心的模板生成功能,並提供生成預覽及代碼文件壓縮下載 準備 首先清楚幾個模塊的關係,如何使用,簡單畫一個流程圖 前面完成了基礎的模板組,模板管理,項目 ...
  • 假設需要實現一個圖標和文本結合的按鈕 ,普通做法是 直接重寫該按鈕的模板; 如果想作為通用的呢? 兩種做法: 附加屬性 自定義控制項 推薦使用附加屬性的形式 第一種:附加屬性 創建Button的附加屬性 ButtonExtensions 1 public static class ButtonExte ...
  • 在C#中,委托是一種引用類型的數據類型,允許我們封裝方法的引用。通過使用委托,我們可以將方法作為參數傳遞給其他方法,或者將多個方法組合在一起,從而實現更靈活的編程模式。委托類似於函數指針,但提供了類型安全和垃圾回收等現代語言特性。 基本概念 定義委托 定義委托需要指定它所代表的方法的原型,包括返回類 ...