日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

常见消息中间件对比

發(fā)布時(shí)間:2023/12/29 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 常见消息中间件对比 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1.ActiveMQ

優(yōu)點(diǎn)

  • 單機(jī)吞吐量:萬級(jí)
  • topic數(shù)量都吞吐量的影響:
  • 時(shí)效性:ms級(jí)
  • 可用性:高,基于主從架構(gòu)實(shí)現(xiàn)高可用性
  • 消息可靠性:有較低的概率丟失數(shù)據(jù)
  • 功能支持:MQ領(lǐng)域的功能極其完備
  • 缺點(diǎn):
    官方社區(qū)現(xiàn)在對(duì)ActiveMQ 5.x維護(hù)越來越少,較少在大規(guī)模吞吐的場(chǎng)景中使用。

    2.Kafka

    號(hào)稱大數(shù)據(jù)的殺手锏,談到大數(shù)據(jù)領(lǐng)域內(nèi)的消息傳輸,則繞不開Kafka,這款為大數(shù)據(jù)而生的消息中間件,以其百萬級(jí)TPS的吞吐量名聲大噪,迅速成為大數(shù)據(jù)領(lǐng)域的寵兒,在數(shù)據(jù)采集、傳輸、存儲(chǔ)的過程中發(fā)揮著舉足輕重的作用。

    Apache Kafka它最初由LinkedIn公司基于獨(dú)特的設(shè)計(jì)實(shí)現(xiàn)為一個(gè)分布式的提交日志系統(tǒng)( a distributed commit log),之后成為Apache項(xiàng)目的一部分。
    目前已經(jīng)被LinkedIn,Uber, Twitter, Netflix等大公司所采納。

    優(yōu)點(diǎn)

  • 性能卓越,單機(jī)寫入TPS約在百萬條/秒,最大的優(yōu)點(diǎn),就是吞吐量高。
  • 時(shí)效性:ms級(jí)
  • 可用性:非常高,kafka是分布式的,一個(gè)數(shù)據(jù)多個(gè)副本,少數(shù)機(jī)器宕機(jī),不會(huì)丟失數(shù)據(jù),不會(huì)導(dǎo)致不可用
  • 消費(fèi)者采用Pull方式獲取消息, 消息有序, 通過控制能夠保證所有消息被消費(fèi)且僅被消費(fèi)一次;
  • 有優(yōu)秀的第三方Kafka Web管理界面Kafka-Manager;
  • 在日志領(lǐng)域比較成熟,被多家公司和多個(gè)開源項(xiàng)目使用;
  • 功能支持:功能較為簡(jiǎn)單,主要支持簡(jiǎn)單的MQ功能,在大數(shù)據(jù)領(lǐng)域的實(shí)時(shí)計(jì)算以及日志采集被大規(guī)模使用
  • 缺點(diǎn):

  • Kafka單機(jī)超過64個(gè)隊(duì)列/分區(qū),Load會(huì)發(fā)生明顯的飆高現(xiàn)象,隊(duì)列越多,load越高,發(fā)送消息響應(yīng)時(shí)間變長(zhǎng)
  • 使用短輪詢方式,實(shí)時(shí)性取決于輪詢間隔時(shí)間;
  • 消費(fèi)失敗不支持重試;
  • 支持消息順序,但是一臺(tái)代理宕機(jī)后,就會(huì)產(chǎn)生消息亂序;
  • 社區(qū)更新較慢;
  • RabbitMQ 2007年發(fā)布,是一個(gè)在AMQP(高級(jí)消息隊(duì)列協(xié)議)基礎(chǔ)上完成的,可復(fù)用的企業(yè)消息系統(tǒng),是當(dāng)前最主流的消息中間件之一。

    3.RabbitMQ優(yōu)點(diǎn):

    優(yōu)點(diǎn)

  • 由于erlang語言的特性,mq 性能較好,高并發(fā);
  • 吞吐量到萬級(jí),MQ功能比較完備
  • 健壯、穩(wěn)定、易用、跨平臺(tái)、支持多種語言、文檔齊全;
  • 開源提供的管理界面非常棒,用起來很好用
  • 社區(qū)活躍度高;
  • RabbitMQ缺點(diǎn):

  • erlang開發(fā),很難去看懂源碼,基本職能依賴于開源社區(qū)的快速維護(hù)和修復(fù)bug,不利于做二次開發(fā)和維護(hù)。
  • RabbitMQ確實(shí)吞吐量會(huì)低一些,這是因?yàn)樗龅膶?shí)現(xiàn)機(jī)制比較重。
  • 需要學(xué)習(xí)比較復(fù)雜的接口和協(xié)議,學(xué)習(xí)和維護(hù)成本較高。
  • 4.RocketMQ

    RocketMQ出自 阿里公司的開源產(chǎn)品,用 Java 語言實(shí)現(xiàn),在設(shè)計(jì)時(shí)參考了 Kafka,并做出了自己的一些改進(jìn)。

    RocketMQ在阿里集團(tuán)被廣泛應(yīng)用在訂單,交易,充值,流計(jì)算,消息推送,日志流式處理,binglog分發(fā)等場(chǎng)景。

    RocketMQ優(yōu)點(diǎn):

  • 單機(jī)吞吐量:十萬級(jí)
  • 可用性:非常高,分布式架構(gòu)
  • 消息可靠性:經(jīng)過參數(shù)優(yōu)化配置,消息可以做到0丟失
  • 功能支持:MQ功能較為完善,還是分布式的,擴(kuò)展性好
  • 支持10億級(jí)別的消息堆積,不會(huì)因?yàn)槎逊e導(dǎo)致性能下降
  • 源碼是java,我們可以自己閱讀源碼,定制自己公司的MQ,可以掌控
  • RocketMQ缺點(diǎn):

  • 支持的客戶端語言不多,目前是java及c++,其中c++不成熟;
  • 社區(qū)活躍度一般
  • 沒有在 mq 核心中去實(shí)現(xiàn)JMS等接口,有些系統(tǒng)要遷移需要修改大量代碼
  • 消息隊(duì)列選擇建議

    1.Kafka

    Kafka主要特點(diǎn)是基于Pull的模式來處理消息消費(fèi),追求高吞吐量,一開始的目的就是用于日志收集和傳輸,適合產(chǎn)生大量數(shù)據(jù)的互聯(lián)網(wǎng)服務(wù)的數(shù)據(jù)收集業(yè)務(wù)。

    大型公司建議可以選用,如果有日志采集功能,肯定是首選kafka了。

    2.RocketMQ

    天生為金融互聯(lián)網(wǎng)領(lǐng)域而生,對(duì)于可靠性要求很高的場(chǎng)景,尤其是電商里面的訂單扣款,以及業(yè)務(wù)削峰,在大量交易涌入時(shí),后端可能無法及時(shí)處理的情況。

    RoketMQ在穩(wěn)定性上可能更值得信賴,這些業(yè)務(wù)場(chǎng)景在阿里雙11已經(jīng)經(jīng)歷了多次考驗(yàn),如果你的業(yè)務(wù)有上述并發(fā)場(chǎng)景,建議可以選擇RocketMQ。

    3.RabbitMQ

    RabbitMQ :結(jié)合erlang語言本身的并發(fā)優(yōu)勢(shì),性能較好,社區(qū)活躍度也比較高,但是不利于做二次開發(fā)和維護(hù)。不過,RabbitMQ的社區(qū)十分活躍,可以解決開發(fā)過程中遇到的bug。

    如果你的數(shù)據(jù)量沒有那么大,小公司優(yōu)先選擇功能比較完備的RabbitMQ。

    以上,是Kafka、RocketMQ、RabbitMQ的優(yōu)劣勢(shì)比較。

    總結(jié)

    以上是生活随笔為你收集整理的常见消息中间件对比的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。