主頁 > 後端開發 > 中間件技術選型

中間件技術選型

2020-11-01 12:56:59 後端開發

常用的 MQ組件有 ActiveMQ、RabbitMQ、RocketMQ、ZeroMQ、MetaMQ,Kafka,當然 Kafka的功能更加強大,雖然不同的 MQ都有自己的特點和優勢,但是,不管是哪種MQ,都有 MQ本身自帶的一些特點,下面,介紹 MQ的特點,

特性ActiveRabbitMQRocketMQKafka
開發語言JavaErlangJavaScala
單擊吞吐量萬級萬級十萬級十萬級
時效性ms級us(微秒)級ms級ms級以內
可用性高(主從架構)高(主從架構)非常高(分布式架構)非常高(分布式架構)
功能特性成熟的產品,在很多公司得到應用,有很多成熟的檔案,支持各種協議并發能力很強,性能及其好,延遲極低,管理界面豐富MQ功能比較完備,擴展性強只支持主要的 MQ功能,向一些訊息查詢,訊息回溯等功能沒有提供,畢竟是為大資料提供的,大資料領域應用廣,

中間件選型


Kafka

Kafka是 LinkedIn開源的分布式發布-訂閱訊息系統,目前歸屬于 Apache頂級專案,Kafka主要特點是基于 Pull的模式來處理訊息,訊息有序,通過控制能夠保證所有訊息被消費且僅被消費一次,追求高吞吐量,一開始的目的就是用于日志收集傳輸,支持復制、事務,對訊息的重復、丟失、錯誤沒有嚴格要求,適合產生大量資料的互聯網服務的資料收集業務,完全的分布式系統,Broker、Producer、Consumer都原生自動支持分布式,自動實作負載均衡,支持 Hadoop資料并行加載,對于像Hadoop的一樣的日志資料和離線分析系統,但又要求實時處理的限制,這是一個可行的解決方案,Kafka通過 Hadoop的并行加載機制來統一了在線和離線的訊息處理,這一點也是本課題所研究系統所看重的,Apache Kafka相對于 ActiveMQ是一個非常輕量級的訊息系統,除了性能非常好之外,還是一個作業良好的分布式系統,詳細博文鏈接

號稱大資料的殺手锏,談到大資料領域內的訊息傳輸,則繞不開Kafka,這款為大資料而生的訊息中間件,以其百萬級TPS(單機寫入TPS約在百萬條/秒的吞吐量名聲大噪,迅速成為大資料領域的寵兒,在資料采集、傳輸、存盤的程序中發揮著舉足輕重的作用,可用性非常高,kafka是分布式的,一個資料多個副本,少數機器宕機,不會丟失資料,不會導致不可用,有優秀的第三方 Kafka Web管理界面 Kafka-Manager

缺點:① Kafka單機超過 64個佇列/磁區,Load會發生明顯的飆高現象,佇列越多,load越高,發送訊息回應時間變長,使用短輪詢方式,實時性取決于輪詢間隔時間,消費失敗不支持重試, 支持訊息順序,但是一臺代理宕機后,就會產生訊息亂序,社區更新較慢,

RabbitMQ

RabbitMQ是使用 Erlang語言開發的開源訊息佇列系統,支持很多的協議 AMQP,XMPP,SMTP,STOMP協議,AMQP的主要特征是面向訊息、佇列、路由(包括點對點和發布/訂閱)、可靠性、安全,AMQP協議使的它變的非常重量級,更適合于企業級的開發,對路由(Routing),負載均衡(Load balance)、資料一致性穩定性可靠性要求很高的場景,對性能和吞吐量的要求還在其次,健壯、穩定、易用、跨平臺、支持多種語言、檔案齊全,開源提供的管理界面非常棒,用起來很好用,社區活躍度高,詳細博文鏈接

缺點:① Erlang開發,很難去看懂原始碼,基本職能依賴于開源社區的快速維護和修復bug,不利于做二次開發和維護, RabbitMQ確實吞吐量會低一些,這是因為他做的實作機制比較重, 需要學習比較復雜的介面和協議,學習和維護成本較高,

RocketMQ

RocketMQ是阿里開源的訊息中間件,它是純 Java開發,具有高吞吐量、高可用性、適合大規模分布式系統應用的特點,RocketMQ思路起源于 Kafka,并做出了自己的一些改進,它對訊息的可靠傳輸事務性做了優化,目前在阿里集團被廣泛應用于交易、充值、流計算、訊息推送、日志流式處理、binglog分發等場景,訊息可靠性非常高,經過引數優化配置,訊息可以做到0丟失,MQ功能較為完善,還是分布式的,擴展性好,支持10億級別的訊息堆積,不會因為堆積導致性能下降,原始碼是 Java,我們可以自己閱讀原始碼,定制自己公司的MQ,可以掌控,

天生為金融互聯網領域而生,對于可靠性要求很高的場景,尤其是電商里面的訂單扣款,以及業務削峰,在大量交易涌入時,后端可能無法及時處理的情況,RoketMQ在穩定性上可能更值得信賴,這些業務場景在阿里雙11已經經歷了多次考驗,如果你的業務有上述并發場景,建議可以選擇RocketMQ,

缺點:① 支持的客戶端語言不多,目前是 java及c++,其中 c++不成熟,社區活躍度一般, 沒有在 MQ核心中去實作 JMS等介面,有些系統要遷移需要修改大量代碼,

ZeroMQ

號稱最快的訊息佇列系統,尤其針對大吞吐量的需求場景,ZMQ能夠實作 RabbitMQ不擅長的高級/復雜的佇列,但是開發人員需要自己組合多種技術框架,技術上的復雜度是對這 MQ能夠應用成功的挑戰,ZeroMQ具有一個獨特的非中間件的模式,你不需要安裝和運行一個訊息服務器或中間件,因為你的應用程式將扮演了這個服務角色,你只需要簡單的參考 ZeroMQ程式庫,可以使用 NuGet安裝,然后你就可以愉快的在應用程式之間發送訊息了,但是 ZeroMQ僅提供非持久性的佇列,也就是說如果 down機,資料將會丟失,其中,Twitter的 Storm中使用 ZeroMQ作為資料流的傳輸,

ActiveMQ

Apache ActiveMQ速度快,支持許多跨語言客戶端和協議,帶有易于使用的企業集成模式和許多高級功能,同時完全支持JMS 1.1和J2EE 1.4,Apache ActiveMQ是在 Apache 2.0許可下發布,有較低的概率丟失資料,詳細博文鏈接

缺點:官方社區現在對 ActiveMQ 5.x維護越來越少較少在大規模吞吐的場景中使用

Redis

是一個 Key-Value的 NoSQL資料庫,開發維護很活躍,雖然它是一個 Key-Value資料庫存盤系統,但它本身支持 MQ功能,所以完全可以當做一個輕量級的佇列服務來使用,對于 RabbitMQ和 Redis的入隊和出隊操作,各執行100萬次,每10萬次記錄一次執行時間,測驗資料分為128Bytes、512Bytes、1K和10K四個不同大小的資料,實驗表明:入隊時,當資料比較小時 Redis的性能要高于 RabbitMQ,而如果資料大小超過了10K,Redis則慢的無法忍受;出隊時,無論資料大小,Redis都表現出非常好的性能,而 RabbitMQ的出隊性能則遠低于 Redis,

壓力測驗


對比Kafka、RabbitMQ、RocketMQ發送訊息(124位元組)的性能,壓測我們只關注服務端的性能指標,所以壓測的標準是不斷增加發送端的壓力,直到系統吞吐量不再上升,而回應時間拉長,這時服務端已出現性能瓶頸,可以獲得相應的系統最佳吞吐量,在同步發送場景中,三個訊息中間件的表現區分明顯:

Kafka

Kafka 的吞吐量高達17.3w/s,是高吞吐量訊息中間件的行業老大,這主要取決于它的佇列模式保證了寫磁盤的程序是線性IO,此時 Broker磁盤IO已達瓶頸,

RocketMQ

RocketMQ也表現不俗,吞吐量在 11.6w/s,磁盤IO已接近100%,RocketMQ的訊息寫入記憶體后即回傳ack,由單獨的執行緒專門做刷盤的操作,所有的訊息均是順序寫檔案

RabbitMQ

RabbitMQ的吞吐量5.95w/s,CPU資源消耗較高,它支持 AMQP協議,實作非常重量級,為了保證訊息的可靠性在吞吐量上做了取舍,我們還做了 RabbitMQ在訊息持久化場景下的性能測驗,吞吐量在 2.6w/s左右,

測驗結論:同步發送的性能上 Kafka>RocketMQ>RabbitMQ

在架構模型方面


RabbitMQ

RabbitMQ遵循 AMQP協議,RabbitMQ的 Broker由 Exchange,Binding,Queue組成,其中 Exchange和 Binding組成了訊息的路由鍵,客戶端 Producer通過連接 Channel和 Server進行通信,Consumer從 Queue獲取訊息進行消費(長連接,Queue有訊息會推送到 Consumer端,Consumer回圈從輸入流讀取資料),RabbitMQ以 Broker為中心,有訊息的確認機制,

Kafka

Kafka遵從一般的 MQ結構,Producer,Broker,Consumer,以 Consumer為中心,訊息的消費資訊保存的客戶端 Consumer上,Consumer根據消費的點,從 Broker上批量 pull資料,無訊息確認機制,

在吞吐量


Kafka

Kafka具有高的吞吐量,內部采用訊息的批量處理zero-copy機制資料的存盤獲取是本地磁盤順序批量操作,具有 O(1)的復雜度,訊息處理的效率很高,

RabbitMQ

RabbitMQ在吞吐量方面稍遜于 Kafka,他們的出發點不一樣,RabbitMQ支持對訊息的可靠的傳遞支持事務不支持批量的操作,基于可靠存盤的要求,存盤可以采用記憶體或者硬碟

在可用性方面


RabbitMQ

RabbitMQ支持 miror的 queue,主 queue失效,miror queue接管,

Kafka

Kafka的 Broker支持主備模式,

在集群負載均衡方面


Kafka

Kafka采用 Zookeeper對集群中的 Broker、Consumer進行管理,可以注冊 Topic到 Zookeeper上,通過 Zookeeper的協調機制,Producer保存對應 Topic的 Broker資訊,可以隨機或者輪詢發送到 Broker上,并且Producer可以基于語意指定分片,訊息發送到 Broker的某分片上,

RabbitMQ

RabbitMQ的負載均衡需要單獨的 loadbalancer進行支持,

總結


Rabbitmq 比 Kafka可靠,Kafka更適合 IO高吞吐的處理,比如 ELK日志收集

Kafka 和 RabbitMq都是以分布式部署為目的,但是他們對訊息語意模型的定義的假設是非常不同的,我對"AMQP 更成熟"這個論點是持懷疑態度的,讓我們用事實說話來看看用什么解決方案來解決你的問題,
【1】以下場景比較適合使用 Kafka,你有大量的事件(10萬以上/秒)、你需要以磁區的,順序的,至少傳遞成功一次到混雜了在線和打包消費的消費者、你希望能重讀訊息、你能接受目前是有限的節點級別高可用或者說你并不介意通過論壇/IRC工具得到還在幼兒階段的軟體的支持,
【2】以下場景你比較適合使用 RabbitMQ,你有較少的事件(2萬以上/秒)并且需要通過復雜的路由邏輯去找到消費者、你希望訊息傳遞是可靠的、你并不關心訊息傳遞的順序、你需要現在就支持集群-節點級別的高可用或則說你需要7*24小時的付費支持(當然也可以通過論壇/IRC工具),

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/198084.html

標籤:python

上一篇:最全SpringBoot學習教程,GitHub上30K+star,幫你解決95%的問題!

下一篇:阿里架構師強烈推薦書籍筆記:Docker+Redis+高并發+Spring

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Rust中的智能指標:Box<T> Rc<T> Arc<T> Cell<T> RefCell<T> Weak

    Rust中的智能指標是什么 智能指標(smart pointers)是一類資料結構,是擁有資料所有權和額外功能的指標。是指標的進一步發展 指標(pointer)是一個包含記憶體地址的變數的通用概念。這個地址參考,或 ” 指向”(points at)一些其 他資料 。參考以 & 符號為標志并借用了他們所 ......

    uj5u.com 2023-04-20 07:24:10 more
  • Java的值傳遞和參考傳遞

    值傳遞不會改變本身,參考傳遞(如果傳遞的值需要實體化到堆里)如果發生修改了會改變本身。 1.基本資料型別都是值傳遞 package com.example.basic; public class Test { public static void main(String[] args) { int ......

    uj5u.com 2023-04-20 07:24:04 more
  • [2]SpinalHDL教程——Scala簡單入門

    第一個 Scala 程式 shell里面輸入 $ scala scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! 檔案形式 object HelloWorld { /* 這是我的第一個 Scala 程式 * 以 ......

    uj5u.com 2023-04-20 07:23:58 more
  • 理解函式指標和回呼函式

    理解 函式指標 指向函式的指標。比如: 理解函式指標的偽代碼 void (*p)(int type, char *data); // 定義一個函式指標p void func(int type, char *data); // 宣告一個函式func p = func; // 將指標p指向函式func ......

    uj5u.com 2023-04-20 07:23:52 more
  • Django筆記二十五之資料庫函式之日期函式

    本文首發于公眾號:Hunter后端 原文鏈接:Django筆記二十五之資料庫函式之日期函式 日期函式主要介紹兩個大類,Extract() 和 Trunc() Extract() 函式作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等資料 Trunc() 的作用則是截取,比如 2022-0 ......

    uj5u.com 2023-04-20 07:23:45 more
  • 一天吃透JVM面試八股文

    什么是JVM? JVM,全稱Java Virtual Machine(Java虛擬機),是通過在實際的計算機上仿真模擬各種計算機功能來實作的。由一套位元組碼指令集、一組暫存器、一個堆疊、一個垃圾回收堆和一個存盤方法域等組成。JVM屏蔽了與作業系統平臺相關的資訊,使得Java程式只需要生成在Java虛擬機 ......

    uj5u.com 2023-04-20 07:23:31 more
  • 使用Java接入小程式訂閱訊息!

    更新完微信服務號的模板訊息之后,我又趕緊把微信小程式的訂閱訊息給實作了!之前我一直以為微信小程式也是要企業才能申請,沒想到小程式個人就能申請。 訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】【企業微信】【釘釘】等訊息型別。 https://gitee.com/zhongfuch ......

    uj5u.com 2023-04-20 07:22:59 more
  • java -- 緩沖流、轉換流、序列化流

    緩沖流 緩沖流, 也叫高效流, 按照資料型別分類: 位元組緩沖流:BufferedInputStream,BufferedOutputStream 字符緩沖流:BufferedReader,BufferedWriter 緩沖流的基本原理,是在創建流物件時,會創建一個內置的默認大小的緩沖區陣列,通過緩沖 ......

    uj5u.com 2023-04-20 07:22:49 more
  • Java-SpringBoot-Range請求頭設定實作視頻分段傳輸

    老實說,人太懶了,現在基本都不喜歡寫筆記了,但是網上有關Range請求頭的文章都太水了 下面是抄的一段StackOverflow的代碼...自己大修改過的,寫的注釋挺全的,應該直接看得懂,就不解釋了 寫的不好...只是希望能給視頻網站開發的新手一點點幫助吧. 業務場景:視頻分段傳輸、視頻多段傳輸(理 ......

    uj5u.com 2023-04-20 07:22:42 more
  • Windows 10開發教程_編程入門自學教程_菜鳥教程-免費教程分享

    教程簡介 Windows 10開發入門教程 - 從簡單的步驟了解Windows 10開發,從基本到高級概念,包括簡介,UWP,第一個應用程式,商店,XAML控制元件,資料系結,XAML性能,自適應設計,自適應UI,自適應代碼,檔案管理,SQLite資料庫,應用程式到應用程式通信,應用程式本地化,應用程式 ......

    uj5u.com 2023-04-20 07:22:35 more