如何保證消息隊列的高可用?

来源:https://www.cnblogs.com/midoujava/archive/2019/09/10/11503856.html
-Advertisement-
Play Games

面試題 如何保證消息隊列的高可用? 面試官心理分析 如果有人問到你 MQ 的知識, 高可用是必問的 。 "上一講" 提到,MQ 會導致 系統可用性降低 。所以只要你用了 MQ,接下來問的一些要點肯定就是圍繞著 MQ 的那些缺點怎麼來解決了。 要是你傻乎乎的就乾用了一個 MQ,各種問題從來沒考慮過,那 ...


關註米兜Java.md

面試題

如何保證消息隊列的高可用?

面試官心理分析

如果有人問到你 MQ 的知識,高可用是必問的上一講提到,MQ 會導致系統可用性降低。所以只要你用了 MQ,接下來問的一些要點肯定就是圍繞著 MQ 的那些缺點怎麼來解決了。

要是你傻乎乎的就乾用了一個 MQ,各種問題從來沒考慮過,那你就杯具了,面試官對你的感覺就是,只會簡單使用一些技術,沒任何思考,馬上對你的印象就不太好了。這樣的同學招進來要是做個 20k 薪資以內的普通小弟還湊合,要是做薪資 20k+ 的高工,那就慘了,讓你設計個系統,裡面肯定一堆坑,出了事故公司受損失,團隊一起背鍋。

面試題剖析

這個問題這麼問是很好的,因為不能問你 Kafka 的高可用性怎麼保證?ActiveMQ 的高可用性怎麼保證?一個面試官要是這麼問就顯得很沒水平,人家可能用的就是 RabbitMQ,沒用過 Kafka,你上來問人家 Kafka 乾什麼?這不是擺明瞭刁難人麽。

所以有水平的面試官,問的是 MQ 的高可用性怎麼保證?這樣就是你用過哪個 MQ,你就說說你對那個 MQ 的高可用性的理解。

RabbitMQ 的高可用性

RabbitMQ 是比較有代表性的,因為是基於主從(非分散式)做高可用性的,我們就以 RabbitMQ 為例子講解第一種 MQ 的高可用性怎麼實現。

RabbitMQ 有三種模式:單機模式、普通集群模式、鏡像集群模式。

單機模式

單機模式,就是 Demo 級別的,一般就是你本地啟動了玩玩兒的

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

-Advertisement-
Play Games
更多相關文章
  • 第十五章 互聯網架構演進 互聯網的浪潮下,各種技術層出不窮,是跟上時代的步伐,還是固守堅固的城池.... 技術選型的問題決定軟體項目的大方向,新舊技術之爭是永恆的焦點。 “不識廬山真面目,只緣身在此山中”,跳出技術的範疇,用業務發展的角度去審視技術,答案就會非常清晰。 1000以內的加減乘除用計算器 ...
  • 目錄: 設計模式六大原則:單一職責原則 設計模式六大原則:介面隔離原則 設計模式六大原則:依賴倒置原則 設計模式六大原則:里氏替換原則 設計模式六大原則:迪米特法則 設計模式六大原則:開閉原則 迪米特法則(LOD): 也叫最少知識原則。迪米特法則的定義是只與你的直接朋友交談,不與"陌生人"說話。如果 ...
  • 第十章 分層架構(面向流程拆分) 保證各層的差異足夠清晰,邊界足夠明顯 隔離關註點 層層傳遞 例如:MVC:分離數據處理,視圖顯示,業務邏輯 第十一章 SOA架構(面向服務拆分) 背景: 企業內部的IT系統重覆建設且效率低下。 企業各部門都有獨立的IT系統,人力資源部門,財務部門,銷售部門....當 ...
  • 前言:引擎組件的基本職責是負責流程流轉,但是在流轉過程中,除了對內部控制邏輯進行實現外,也不可避免的要去調用或者響應外部事件。本文主要描述外部事件的類型,以及調用方法過程。 1. 外部事件的類型 外部事件的類型是隨著引擎功能的需要而不斷增加,開發人員也可以在此基礎上進行擴展,目前主要常用的事件類型如 ...
  • day-4作業 1.簡述Python的五大數據類型的作用、定義方式、使用方法: 1.數字類型 不知道 2.字元串類型 不知道 3.列表 作用:儲存多個(任意數據類型)元素 定義方式:[]用逗號‘’隔開多個元素[任意數據類型] 使用方法:索[搜索]引[引路]取值,以0為開始,也可以倒數為-1開始。 3 ...
  • python入門,print ,運算符, 變數,input,解決問題。 ...
  • 為了更好的管理應用的配置,也為了不用每次更改配置文件都重啟,我們可以使用配置中心 關於eureka的服務註冊和rabbitMQ的安裝使用(自動更新配置需要用到rabbitMQ)這裡不贅述,只關註配置中心的內容 我們需要引入關鍵的包是這三個 需要在啟動類加上@EnableConfigServer註解, ...
  • 這裡建議先去看看路徑的問題,看看application.xml的裡面的導入的相應的配置文件的路徑有沒有問題,如下: 再者看看相應的註解有沒有加上,service和controller等的註解 如果再不行,在pon.xml文件加上下麵的: <build><resources> <!--編譯之後包含xm ...
一周排行
    -Advertisement-
    Play Games
  • 基於.NET Framework 4.8 開發的深度學習模型部署測試平臺,提供了YOLO框架的主流系列模型,包括YOLOv8~v9,以及其系列下的Det、Seg、Pose、Obb、Cls等應用場景,同時支持圖像與視頻檢測。模型部署引擎使用的是OpenVINO™、TensorRT、ONNX runti... ...
  • 十年沉澱,重啟開發之路 十年前,我沉浸在開發的海洋中,每日與代碼為伍,與演算法共舞。那時的我,滿懷激情,對技術的追求近乎狂熱。然而,隨著歲月的流逝,生活的忙碌逐漸占據了我的大部分時間,讓我無暇顧及技術的沉澱與積累。 十年間,我經歷了職業生涯的起伏和變遷。從初出茅廬的菜鳥到逐漸嶄露頭角的開發者,我見證了 ...
  • C# 是一種簡單、現代、面向對象和類型安全的編程語言。.NET 是由 Microsoft 創建的開發平臺,平臺包含了語言規範、工具、運行,支持開發各種應用,如Web、移動、桌面等。.NET框架有多個實現,如.NET Framework、.NET Core(及後續的.NET 5+版本),以及社區版本M... ...
  • 前言 本文介紹瞭如何使用三菱提供的MX Component插件實現對三菱PLC軟元件數據的讀寫,記錄了使用電腦模擬,模擬PLC,直至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1. PLC開發編程環境GX Works2,GX Works2下載鏈接 https:// ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • 1、jQuery介紹 jQuery是什麼 jQuery是一個快速、簡潔的JavaScript框架,是繼Prototype之後又一個優秀的JavaScript代碼庫(或JavaScript框架)。jQuery設計的宗旨是“write Less,Do More”,即倡導寫更少的代碼,做更多的事情。它封裝 ...
  • 前言 之前的文章把js引擎(aardio封裝庫) 微軟開源的js引擎(ChakraCore))寫好了,這篇文章整點js代碼來測一下bug。測試網站:https://fanyi.youdao.com/index.html#/ 逆向思路 逆向思路可以看有道翻譯js逆向(MD5加密,AES加密)附完整源碼 ...
  • 引言 現代的操作系統(Windows,Linux,Mac OS)等都可以同時打開多個軟體(任務),這些軟體在我們的感知上是同時運行的,例如我們可以一邊瀏覽網頁,一邊聽音樂。而CPU執行代碼同一時間只能執行一條,但即使我們的電腦是單核CPU也可以同時運行多個任務,如下圖所示,這是因為我們的 CPU 的 ...
  • 掌握使用Python進行文本英文統計的基本方法,並瞭解如何進一步優化和擴展這些方法,以應對更複雜的文本分析任務。 ...
  • 背景 Redis多數據源常見的場景: 分區數據處理:當數據量增長時,單個Redis實例可能無法處理所有的數據。通過使用多個Redis數據源,可以將數據分區存儲在不同的實例中,使得數據處理更加高效。 多租戶應用程式:對於多租戶應用程式,每個租戶可以擁有自己的Redis數據源,以確保數據隔離和安全性。 ...