一.RocketMQ概念

RocketMQ概念

    • 1.概念
    • 2.應用場景
    • 3.MQ的優點和缺點
    • 4.常見MQ對比

1.概念

MQ(Message Queue),是一種提供消息隊列服務的中間件,也稱為消息中間件,是一套提供了消息生產、存儲、消費全過程API的軟件系統。

在這里插入圖片描述

RocketMQ是阿里巴巴2016年MQ中間件,使用Java語言開發,阿?巴巴向 Apache 軟件基?會捐贈RocketMQ,成為 Apache 孵化項?。

2.應用場景

 1)應用解耦系統的耦合性越高,容錯性就越低。上游系統對下游系統的調用若為同步調用,則會大大降低系統的吞吐量與并發量,且系統耦合度太高。而異步調用則會解決這些問題。所以兩層之間若要實現由同步到異步的轉化,一般性做法就是,在這兩層間添加一個MQ層。

在這里插入圖片描述
使用消息隊列解耦合,系統的耦合性就會提高了。比如物流系統發生故障,需要幾分鐘才能修復,在這段時間內,物流系統要處理的數據被緩存到消息隊列中,用戶的下單操作正常完成。當物流系統恢復后,補充處理存在消息隊列中的訂單消息即可,終端系統感知不到物流系統發生過幾分鐘故障。
在這里插入圖片描述

2)流量削峰
應用系統如果遇到系統請求流量的瞬間猛增,有可能會將系統壓垮。
有了消息隊列可以將大量請求緩存起來,分散到很長一段時間處理,這樣可以大大提高系統的穩定性和用戶體驗。
一般情況,為了保證系統的穩定性,如果系統負載超過閾值,就會阻止用戶請求,這會影響用戶體驗。而如果使用消息隊列將請求暫存起來,后續按一定速率處理,會在一定程度提升體驗。

在這里插入圖片描述

3)數據分發
通過消息隊列可以讓數據在多個系統之間進行流通。數據的產生方不需要關心誰來使用數據,只需要將數據發送到消息隊列,數據使用方直接在消息隊列中直接獲取數據即可。

3.MQ的優點和缺點

優點:解耦、削峰、數據分發
缺點

  • 系統可用性降低
    系統引入的外部依賴越多,系統穩定性越差。一旦MQ宕機,就會對業務造成影響。如何保證MQ的高可用?
  • 系統復雜度提高
    MQ的加入大大增加了系統的復雜度,以前系統間是同步的遠程調用,現在是通過MQ進行異步調用。
    如何保證消息沒有被重復消費?怎么處理消息丟失情況?那么保證消息傳遞的順序性?
  • 一致性問題
    A系統處理完業務,通過MQ給B、C、D三個系統發消息數據,如果B系統、C系統處理成功,D系統處理失敗。
    如何保證消息數據處理的一致性?

4.常見MQ對比

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/40224.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/40224.shtml
英文地址,請注明出處:http://en.pswp.cn/news/40224.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Error: Couldn‘t find preset “es2015“ relative to directory

vue引入element-ui,運行時報了這個錯誤 Module build failed: Error: Couldnt find preset "es2015" relative to directory "D:\\360MoveData\\Users\\Administrator\\Desktop\\新建文件夾\\henge-test"at D:\360MoveData\Users\Administrato…

華為云classroom賦能--Devstar使應用開發無需從零開始

華為云DevStar為開發者提供業界主流框架代碼初始化能力,通過GUI、API、CLI等多種方式,將按模板生成框架代碼的能力推送至用戶桌面。同時基于華為云服務資源、成熟的DevOps開發工具鏈和面向多場景的眾多開發模板,提供一站式創建代碼倉、自動生…

Windows server 2016如何安裝OpenSSH

在 Windows Server 2016 上安裝 OpenSSH 需要通過“添加功能和角色”向導來完成。以下是安裝 OpenSSH 的步驟: 1.打開 Windows Server 2016 控制面板。 2.點擊 "程序",然后選擇 "程序和功能"。 3.在左側菜單中,點擊 &…

【golang】數組和切片底層原理

數組類型的值(以下簡稱數組)的長度是固定的,而切片類型的值(以下簡稱切片)是可變長的。 數組的長度在聲明它的時候就必須給定,并且之后不會再改變。可以說,數組的長度是其類型的一部分。比如&a…

Spring學習筆記之Spring IoC注解式開發

文章目錄 聲明Bean的注解Component注解Controller注解Service注解Repository Spring注解的使用選擇性實例化Bean負責注入的注解ValueAutowired與QuaifierResource 全注解式開發 注解的存在主要是為了簡化XML的配置。Spring6倡導全注解開發 注解怎么定義,注解中的屬性…

深入探索JavaEE單體架構、微服務架構與云原生架構

課程鏈接: 鏈接: https://pan.baidu.com/s/1xSI1ofwYXfqOchfwszCZnA?pwd4s99 提取碼: 4s99 復制這段內容后打開百度網盤手機App,操作更方便哦 --來自百度網盤超級會員v4的分享 課程介紹: 🔍【00】模塊零:開營直播&a…

ARM-M0內核MCU,內置24bit ADC,采樣率4KSPS,傳感器、電子秤、體脂秤專用,國產IC

ARM-M0內核MCU 內置24bit ADC ,采樣率4KSPS flash 64KB,SRAM 32KB 適用于傳感器,電子秤,體脂秤等等

[BitSail] Connector開發詳解系列三:SourceReader

更多技術交流、求職機會,歡迎關注字節跳動數據平臺微信公眾號,回復【1】進入官方交流群 Source Connector 本文將主要介紹負責數據讀取的組件SourceReader: SourceReader 每個SourceReader都在獨立的線程中執行,只要我們保證Sou…

Jmeter進階使用:BeanShell實現接口前置和后置操作

一、背景 我們使用Jmeter做壓力測試或者接口測試時,除了最簡單的直接對接口發起請求,很多時候需要對接口進行一些前置操作:比如提前生成測試數據,以及一些后置操作:比如提取接口響應內容中的某個字段的值。舉個最常用…

c語言——拷貝數組

這段代碼是一個簡單的數組拷貝示例。它的功能是將一個原始數組 original 的內容拷貝到另一個數組 copied 中,并輸出兩個數組的元素。 代碼執行過程如下: 首先,在 main() 函數中定義了一個整型數組 original,并初始化了它的元素。…

【ARM 嵌入式 編譯 Makefile 系列 15 - Makefile define 宏與調用宏函數詳細介紹】

文章目錄 Makefile define 宏與調用宏函數帶參數的宏函數帶返回值的宏函數Makefile define 宏與調用宏函數 在Makefile中,可以通過define關鍵字來定義一個多行的宏(也稱為變量)。這種宏定義通常用于定義一個復雜的命令序列,然后在其他地方調用。 以下是定義一個宏的例子:…

物聯網在制造業中的應用

制造業目前正在經歷第四次工業革命,物聯網、人工智能和機器人等技術進步正在推動行業的發展。研究表明,到2024年,全球制造商將在物聯網解決方案上投資700億美元,許多制造商正在實施物聯網設備,以利用預測性維護和復雜的…

接口測試工具——Postman測試工具 Swagger接口測試+SpringBoot整合 JMeter高并發測試工具

目錄 Postman測試工具接口測試工具swaggerKnife4j1.引入依賴2.配置3.常用注解4.接口測試 JMeter什么是JMeter?JMeter安裝配置1.官網下載2.下載后解壓3.漢語設置 JMeter的使用方法1.新建線程組2.設置參數3.添加取樣器4.設置參數:協議,ip,端口…

SDK是什么,SDK和API有什么區別

SDK(Software Development Kit)是一種開發工具包,通常由軟件開發公司或平臺提供,用于幫助開發人員構建、測試和集成特定平臺或軟件的應用程序。SDK 包含一系列的庫、工具、示例代碼和文檔,旨在簡化開發過程并提供所需的…

基于Mysql+Vue+Django的協同過濾和內容推薦算法的智能音樂推薦系統——深度學習算法應用(含全部工程源碼)+數據集

目錄 前言總體設計系統整體結構圖系統流程圖 運行環境Python 環境MySQL環境VUE環境 模塊實現1. 數據請求和儲存2. 數據處理計算歌曲、歌手、用戶相似度計算用戶推薦集 3. 數據存儲與后臺4. 數據展示 系統測試工程源代碼下載其它資料下載 前言 本項目以豐富的網易云音樂數據為基…

SQLSERVER 查詢語句加with (NOLOCK) 報ORDER BY 報錯 除非另外還指定了 TOP、OFFSET 或 FOR XML

最近有一個項目在客戶使用時發現死鎖問題,用的數據庫是SQLSERVER ,死鎖的原因是有的客戶經常去點報表,報表查詢時間又慢,然后又有人在做單導致了死鎖,然后主管要我們用SQLSERVER查詢時要加with (NOLOCK),但是我在加完 …

YOLOv5模型訓練流程

此文章只是記錄使用,以便后續查看,不作為教程,剛接觸,可能有錯誤 YOLOv5模型訓練流程 一、數據集的準備 1.在源碼根目錄新建mydata文件夾,在此文件夾下新建images和labels文件夾 目錄樹如下: ├───…

鏈表---

題目描述 一個學校里老師要將班上 N 個同學排成一列,同學被編號為 1~N,他采取如下的方法: 先將 11 號同學安排進隊列,這時隊列中只有他一個人; 2~N 號同學依次入列,編號為 i 的同學入列方式為&#xff…

2023骨傳導耳機推薦,適合運動骨傳導耳機推薦

相信很多人跟我一樣,隨著現在五花八門的耳機品種增多,選耳機的時候真是眼花繚亂,尤其還是網購,只能看,不能試,所以選擇起來比較困難, 作為一個運動達人,為了讓大家在購買耳機時少走彎…

〔012〕Stable Diffusion 之 中文提示詞自動翻譯插件 篇

? 目錄 🎈 翻譯插件🎈 下載谷歌翻譯🎈 谷歌翻譯使用方法🎈 谷歌翻譯使用效果 🎈 翻譯插件 在插件列表中搜索 Prompt Translator可以看到有2個插件選項:一個是基于谷歌翻譯 〔推薦〕、一個基于百度和deepl…