今天咱們一塊兒來探討:html
那麼目前在業界有哪些比較知名的消息引擎呢?以下圖所示java
這裏面幾乎徹底列舉了當下比較知名的消息引擎,包括:c++
1.解耦後端
解耦是消息隊列要解決的最本質問題。架構
2.最終一致性併發
最終一致性指的是兩個系統的狀態保持一致,要麼都成功,要麼都失敗。分佈式
最終一致性不是消息隊列的必備特性,但確實能夠依靠消息隊列來作最終一致性的事情。高併發
2.廣播性能
消息隊列的基本功能之一是進行廣播。學習
有了消息隊列,咱們只須要關心消息是否送達了隊列,至於誰但願訂閱,是下游的事情,無疑極大地減小了開發和聯調的工做量。
3.錯峯與流控
典型的使用場景就是秒殺業務用於流量削峯場景。
因爲篇幅的關係,本文重點介紹消息隊列比較,詳細應用場景請參考:什麼是流量削峯?如何解決秒殺業務的削峯場景
優勢
缺點:
官方社區如今對ActiveMQ 5.x維護愈來愈少,較少在大規模吞吐的場景中使用。
號稱大數據的殺手鐗,談到大數據領域內的消息傳輸,則繞不開Kafka,這款爲大數據而生的消息中間件,以其百萬級TPS的吞吐量名聲大噪,迅速成爲大數據領域的寵兒,在數據採集、傳輸、存儲的過程當中發揮着舉足輕重的做用。
Apache Kafka它最初由LinkedIn公司基於獨特的設計實現爲一個分佈式的提交日誌系統( a distributed commit log),以後成爲Apache項目的一部分。
目前已經被LinkedIn,Uber, Twitter, Netflix等大公司所採納。
優勢
缺點:
RabbitMQ 2007年發佈,是一個在AMQP(高級消息隊列協議)基礎上完成的,可複用的企業消息系統,是當前最主流的消息中間件之一。
RabbitMQ優勢:
RabbitMQ缺點:
RocketMQ出自 阿里公司的開源產品,用 Java 語言實現,在設計時參考了 Kafka,並作出了本身的一些改進。
RocketMQ在阿里集團被普遍應用在訂單,交易,充值,流計算,消息推送,日誌流式處理,binglog分發等場景。
RocketMQ優勢:
RocketMQ缺點:
1.Kafka
Kafka主要特色是基於Pull的模式來處理消息消費,追求高吞吐量,一開始的目的就是用於日誌收集和傳輸,適合產生大量數據的互聯網服務的數據收集業務。
大型公司建議能夠選用,若是有日誌採集功能,確定是首選kafka了。
2.RocketMQ
天生爲金融互聯網領域而生,對於可靠性要求很高的場景,尤爲是電商裏面的訂單扣款,以及業務削峯,在大量交易涌入時,後端可能沒法及時處理的狀況。
RoketMQ在穩定性上可能更值得信賴,這些業務場景在阿里雙11已經經歷了屢次考驗,若是你的業務有上述併發場景,建議能夠選擇RocketMQ。
3.RabbitMQ
RabbitMQ :結合erlang語言自己的併發優點,性能較好,社區活躍度也比較高,可是不利於作二次開發和維護。不過,RabbitMQ的社區十分活躍,能夠解決開發過程當中遇到的bug。
若是你的數據量沒有那麼大,小公司優先選擇功能比較完備的RabbitMQ。