RabbitMQ/Kafka/ZeroMQ 區(qū)別

本質(zhì)上都是MQ,但區(qū)別也較大,解決的問(wèn)題不一樣,層次不同。除了編程語(yǔ)言和執(zhí)行性能的區(qū)別之外,最大的區(qū)別:

1、通信模式的區(qū)別常見(jiàn)消息隊(duì)列實(shí)現(xiàn)了pub/sub模式,而zeromq提供了若干種。

2、有沒(méi)有broker的區(qū)別常見(jiàn)消息隊(duì)列是由broker來(lái)代理消息的持久化和轉(zhuǎn)發(fā)的,而zeromq沒(méi)有broker。但是你也不能說(shuō)zeromq不是mq,或者說(shuō)“zeromq在mq之下”、“僅僅是個(gè)網(wǎng)絡(luò)庫(kù)”,只要有先進(jìn)先出+消息(不是流),就都可以自稱(chēng)是mq。

3、分布式一致性的區(qū)別常見(jiàn)分布式消息隊(duì)列的broker之間通過(guò)zookeeper、raft等實(shí)現(xiàn)了分布式一致性,分布式管理已經(jīng)替你解決了。在構(gòu)建分布式系統(tǒng)時(shí),如果需要一個(gè)解耦的、可分布式擴(kuò)展的消息系統(tǒng),此時(shí),zeromq沒(méi)有提供分布式管理功能。這個(gè)場(chǎng)景下,和企業(yè)級(jí)MQ相比,zeromq顯得更像一個(gè)易用的socket而已,但你不能否認(rèn)zeromq實(shí)現(xiàn)了mq的核心功能——消息(而不是流)+先進(jìn)先出。其他有諸如持久化等等區(qū)別,但和分布式特性類(lèi)似,且更加遠(yuǎn)離MQ的本質(zhì)概念范疇了。只是說(shuō),為了滿(mǎn)足現(xiàn)在大規(guī)模系統(tǒng)的需要,消息層往往需要分布式和持久化等等很多很多保障,所以給MQ加了很多附加要求,但是始終牢記,MQ的本質(zhì)就是消息+隊(duì)列。

RabbitMQ 選型和對(duì)比

1.從社區(qū)活躍度

按照目前網(wǎng)絡(luò)上的資料,RabbitMQ
、activeM
、ZeroMQ
三者中,綜合來(lái)看,RabbitMQ
是首選。

2.持久化消息比較

ZeroMq
不支持,ActiveMq
和RabbitMq
都支持。持久化消息主要是指我們機(jī)器在不可抗力因素等情況下掛掉了,消息不會(huì)丟失的機(jī)制。

3.綜合技術(shù)實(shí)現(xiàn)

可靠性、靈活的路由、集群、事務(wù)、高可用的隊(duì)列、消息排序、問(wèn)題追蹤、可視化管理工具、插件系統(tǒng)等等。
RabbitMq
/ Kafka
最好,ActiveMq
次之,ZeroMq
最差。當(dāng)然ZeroMq
也可以做到,不過(guò)自己必須手動(dòng)寫(xiě)代碼實(shí)現(xiàn),代碼量不小。尤其是可靠性中的:持久性、投遞確認(rèn)、發(fā)布者證實(shí)和高可用性。

4.高并發(fā)

毋庸置疑,RabbitMQ
最高,原因是它的實(shí)現(xiàn)語(yǔ)言是天生具備高并發(fā)高可用的erlang
語(yǔ)言。

5.比較關(guān)注的比較, RabbitMQ 和 Kafka

RabbitMq
比Kafka
成熟,在可用性上,穩(wěn)定性上,可靠性上, RabbitMq勝于 Kafka] (理論上)。
另外,Kafka
的定位主要在日志等方面, 因?yàn)镵afka
設(shè)計(jì)的初衷就是處理日志的,可以看做是一個(gè)日志(消息)系統(tǒng)一個(gè)重要組件,針對(duì)性很強(qiáng),所以 如果業(yè)務(wù)方面還是建議選擇 RabbitMq
。
還有就是,Kafka
的性能(吞吐量、TPS
)比RabbitMq
要高出來(lái)很多。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 本文轉(zhuǎn)載自http://dataunion.org/?p=9307 背景介紹Kafka簡(jiǎn)介Kafka是一種分布式的...
    Bottle丶Fish閱讀 5,588評(píng)論 0 34
  • 背景介紹 Kafka簡(jiǎn)介 Kafka是一種分布式的,基于發(fā)布/訂閱的消息系統(tǒng)。主要設(shè)計(jì)目標(biāo)如下: 以時(shí)間復(fù)雜度為O...
    高廣超閱讀 13,057評(píng)論 8 167
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,618評(píng)論 19 139
  • Kafka系列一- Kafka背景及架構(gòu)介紹 Kafka簡(jiǎn)介 Kafka是一種分布式的,基于發(fā)布/訂閱的消息系統(tǒng)。...
    raincoffee閱讀 2,336評(píng)論 0 22
  • 關(guān)于消息隊(duì)列,從前年開(kāi)始斷斷續(xù)續(xù)看了些資料,想寫(xiě)很久了,但一直沒(méi)騰出空,近來(lái)分別碰到幾個(gè)朋友聊這塊的技術(shù)選型,是時(shí)...
    預(yù)流閱讀 586,637評(píng)論 51 787

友情鏈接更多精彩內(nèi)容