消息中間件|初識消息隊列

文章目錄

  • 消息隊列是什么?
  • 消息隊列關鍵概念
  • 消息隊列優點
  • 消息隊列的應用場景
    • 異步處理
    • 應用解耦
    • 流量削峰
    • 消息通訊
  • 常用消息隊列中間件的對比

消息隊列是什么?

  • 消息隊列(Message Queue)是一種用于在軟件系統之間傳遞消息的通信機制。其本質是一個保存數據的隊列,它通常被用于解耦不同組件或模塊之間的通信,以實現異步通信、提高系統的可伸縮性和可靠性。
  • 消息中間件是利用高效可靠的消息傳遞機制進行與平臺無關的數據交流,并基于數據通信來進行分布式系統的構建。
  • 消息中間件是分布式系統中重要的組件,主要解決應用解耦、異步消息、流量削峰等問題,實現高性能、高可用、可伸縮和最終一致性的系統架構。目前常見的消息隊列系統包括Apache KafkaRabbitMQRocketMQActiveMQ等。

消息隊列關鍵概念

  • 消息生產者(Producer):負責產生消息并將其發送到消息隊列中。
  • 消息隊列(Message Queue):用于存儲消息的緩沖區或中介。消息隊列可以是內存中的數據結構,也可以是持久化的存儲系統。
  • 消息消費者(Consumer):從消息隊列中獲取消息,并進行相應的處理。消費者負責處理消息的邏輯,通常是異步地從隊列中拉取消息。
  • 消息:要在系統中傳遞的數據單元。消息可以是任何形式的數據,如文本、JSONXML 等。

消息隊列優點

  • 解耦性:生產者和消費者之間通過消息隊列進行通信,彼此不需要直接連接,降低了耦合度。
  • 異步通信:生產者和消費者可以獨立運行,不需要等待對方的響應。
  • 增強系統可靠性:即使一個組件或模塊不可用,消息仍然可以被存儲在隊列中,待組件恢復后繼續處理。
  • 緩沖能力:消息隊列可以作為緩沖,處理高峰時段的突發流量,以及平滑系統的負載。

消息隊列的應用場景

異步處理

將一些非核心的業務流程以異步并行的方式執行,從而減少請求響應時間,提高系統吞吐量。

應用解耦

就是接觸應用系統之間的耦合依賴,通過消息隊列,使每個應用系統不必受其他系統影響,可以更獨立自主。

流量削峰

流量削峰一般在秒殺和團搶活動中使用廣泛,在應用前端加入消息隊列,秒殺業務處理系統根據消息隊列中的請求信息,再做后續處理。

消息通訊

消息通訊是指應用間的數據通信。消息隊列一般都內置了高效的通信機制,因此可以用在純的消息通訊。比如實現點對點消息隊列,或者聊天室等對點通訊。

常用消息隊列中間件的對比

目前常見的消息隊列系統包括 Apache KafkaRabbitMQRocketMQActiveMQ等,選擇合適的消息隊列取決于應用的需求、性能要求以及可用的基礎設施。

kafkaRabbitMQRocketMQActiveMQ
資料文檔中等
開發語言ScalaEriangJavaJava
支持協議自定義(基于TCP)AMQP自定義OpenWire、STOMP、RESR、XMPP、AMQP
消息存儲內存、磁盤、數據庫;支持大量堆積內存、磁盤;支持少量堆積磁盤;支持大量堆積內存,磁盤,數據庫;支持少量堆積
消息事務支持支持支持支持
負載均衡支持支持支持可基于zk實現負載均衡
集群管理leader-slave支持簡單集群master-slave支持簡單集群
管理界面一般很好一般
可用性非常高非常高
吞吐TPS極大比較大比較大
順序消息支持不支持支持不支持
消息確認支持支持支持支持
消息回調支持指定分區offset位置回調不支持支持指定時間點的回調不支持
消息重試不支持不支持支持不支持
并發度極高

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

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

相關文章

spring boot概述

SpringBoot是由Pivotal團隊提供的全新框架,其設計目的是用來簡化新Spring應用的初始搭建以及開發過程。 該框架使用了特定的方式來進行配置,從而使開發人員不再需要定義樣板化的配置。 通過這種方式,SpringBoot致力于在蓬勃發展的快速應用開發…

實時抓取SKU商品屬性詳細信息API數據接口(淘寶,某音)

item_sku-獲取sku詳細信息 taobao.item_sku詳細信息 API公共參數 請求地址: https://api-gw.onebound.cn/taobao/item_sku 名稱類型必須描述keyString是調用key(演示示例)secretString是調用密鑰api_nameString是API接口名稱(包括在請求地…

設計模式學習筆記 - 設計原則 - 3.里氏替換原則,它和多態的區別是什么?

前言 今天來學習 SOLID 中的 L:里氏替換原則。它的英文翻譯是 Liskov Substitution Principle,縮寫為 LSP。 英文原話是: Functions that use points of references of base classes must be able to use objects of derived classes withou…

python-分享篇-生成仿微信公眾號推廣的個性二維碼(支持動態)

代碼 生成仿微信公眾號推廣的個性二維碼(支持動態)from MyQR import myqr # 要生成動態二維碼,只需要將piture參數和save_name參數設置gif動圖即可 myqr.run(wordshttps://blog.csdn.net/stqer/article/details/135553200, # 指定二維碼包含…

JVM(內存區域劃分)

JVM JVM - Java虛擬機 我們編寫的 Java 程序, 是不能夠被 OS 直接識別的 JVM 充當翻譯官的角色, 負責把我們寫的的 Java 程序 ,翻譯給 OS “聽”, 讓 OS 能夠識別我們所寫的 Java 代碼 JVM 內存區域劃分 JVM 是一個應用程序, 在啟動的時候, 會從 操作系統 申請到一整塊很大的內…

AI-RAN聯盟在MWC24上正式啟動

AI-RAN聯盟在MWC24上正式啟動。它的logo是這個樣的: 2月26日,AI-RAN聯盟(AI-RAN Alliance)在2024年世界移動通信大會(MWC 2024)上成立。創始成員包括亞馬遜云科技、Arm、DeepSig、愛立信、微軟、諾基亞、美…

【dc-dc】AP510X單路低壓差線性恒流芯片

說明 AP510X 是一系列外圍電路簡潔的單路線性 LED 恒 流芯片,適用于 3-60V 電壓范圍的 LED 恒流調光 領域。 AP510X 采用我司專利算法,可以實現高精度的恒 流效果,輸出電流恒流精度≤ 3 %,電源供電工作 范…

【LeetCode】升級打怪之路 Day 11:棧的應用、單調棧

今日題目: Problem 1: 棧的應用 155. 最小棧 | LeetCode20. 有效的括號 | LeetCode150. 逆波蘭表達式求值 | LeetCode Problem 2: 單調棧 496. 下一個更大元素 I739. 每日溫度503. 下一個更大元素 II 目錄 Problem 1:棧 - “先進后出”的應用LC 155. 最…

【Java設計模式】五、建造者模式

文章目錄 1、建造者模式2、案例:共享單車的創建3、其他用途 1、建造者模式 某個對象的構建復雜將復雜的對象的創建 和 屬性賦值所分離,使得同樣的構建過程可以創建不同的表示建造的過程和細節調用者不需要知道,只需要通過構建者去進行操作 …

力扣刷題記錄--463. 島嶼的周長

題目鏈接&#xff1a;463. 島嶼的周長 - 力扣&#xff08;LeetCode&#xff09; 題目描述 我的代碼實現 class Solution {public int islandPerimeter(int[][] grid) { int result0; int rowgrid.length; int colgrid[0].length; for(int i0;i<row;i){for(int j0;j<col…

【EI會議征稿通知】2024年圖像處理與人工智能國際學術會議(ICIPAI2024)

2024年圖像處理與人工智能國際學術會議&#xff08;ICIPAI2024&#xff09; 2024 International Conference on Image Processing and Artificial Intelligence&#xff08;ICIPAI2024&#xff09; 2024年圖像處理與人工智能國際學術會議&#xff08;ICIPAI2024&#xff09;將…

返回靜態數據

在Java項目中&#xff0c;往往不會一直返回某某數據&#xff0c;而是會返回一個靜態頁面&#xff0c;那么&#xff0c;如何正確返回一個靜態頁面呢&#xff1f;&#xff1f; 要想成功的返回一個靜態頁面前提是必須要有一個靜態頁面&#xff1a; <!DOCTYPE html> <ht…

如何讓 JOIN 跑得更快?

JOIN 一直是數據庫性能優化的老大難問題&#xff0c;本來挺快的查詢&#xff0c;一旦涉及了幾個 JOIN&#xff0c;性能就會陡降。而且&#xff0c;參與 JOIN 的表越大越多&#xff0c;性能就越難提上來。 其實&#xff0c;讓 JOIN 跑得快的關鍵是要對 JOIN 分類&#xff0c;分…

Effective Programming 學習筆記

1 基本語句 1.1 斷言 在南溪看來&#xff0c;斷言可以用來有效地確定編程中當前代碼運行的前置條件&#xff0c;尤其是以下情況&#xff1a; 第三方工具庫對輸入數據的依賴&#xff0c;例如&#xff1a;minitouch庫對Android版本的要求

第三百八十一回

文章目錄 1. 概念介紹2. 修改方法 015buttonStyle.png2.1 修改形狀2.2 修改顏色2.3 修改位置 3. 示例代碼4. 內容總結 我們在上一章回中介紹了"如何創建以圖片為背景的頁面"相關的內容&#xff0c;本章回中將介紹如何修改按鈕的形狀.閑話休提&#xff0c;讓我們一起T…

2024年華為OD機試真題-文件緩存系統-Python-OD統一考試(C卷)

題目描述: 請設計一個文件緩存系統,該文件緩存系統可以指定緩存的最大值(單位為字節)。 文件緩存系統有兩種操作:存儲文件(put)和讀取文件(get) 操作命令為put fileName fileSize或者get fileName 存儲文件是把文件放入文件緩存系統中;讀取文件是從文件緩存系統中訪問已存…

06. Nginx進階-Nginx代理服務

proxy代理功能 正向代理 什么是正向代理&#xff1f; 正向代理&#xff08;forward proxy&#xff09;&#xff0c;一個位于客戶端和原始服務器之間的服務器。 工作原理 為了從原始服務器獲取內容&#xff0c;客戶端向代理發送一個請求并指定目標&#xff08;即原始服務器…

為不同文章形式選擇不同的WordPress文章模板

在寫文章的時候選擇不同的文章形式&#xff0c;然后打開文章的時候會調用不同文章形式的模板。比如&#xff0c;文章形式為video &#xff0c;就調用single-video.php模板&#xff0c;其它文章形式類似&#xff0c;可以添加多個文章樣式。 //為不同文章形式的內容添加不同的si…

chatgpt-next-web搭建教程,超低成本部署屬于自己的ChatGPT

隨著AI的應用變廣&#xff0c;各類AI程序已逐漸普及&#xff0c;尤其是在一些日常辦公、學習等與撰寫/翻譯文稿密切相關的場景&#xff0c;大家都希望找到一個適合自己的穩定可靠的ChatGPT軟件來使用。 ChatGPT-Next-Web就是一個很好的選擇。它是一個Github上超人氣的免費開源…

Spring AOP在業務中常見的使用方式

目錄 1、動態代理 1.1、jdk動態代理 1.2、cglib動態代理 1.3、動態代理的好處 2、什么是AOP 2.1、AOP常用術語 2.2、切面的構成 3、使用aspectJ框架實現AOP 3.1、aspectJ簡介 聲明實現類ServiceImpl 聲明切面 3.3、AfterReturning后置通知 切面類代碼 3.4、Aroun…