當前位置:編程學習大全網 - 編程語言 - 消息中間件(壹)MQ詳解及四大MQ比較

消息中間件(壹)MQ詳解及四大MQ比較

壹、消息中間件相關知識

1、概述

消息隊列已經逐漸成為企業IT系統內部通信的核心手段。它具有低耦合、可靠投遞、廣播、流量控制、最終壹致性等壹系列功能,成為異步RPC的主要手段之壹。當今市面上有很多主流的消息中間件,如老牌的ActiveMQ、RabbitMQ,炙手可熱的Kafka,阿裏巴巴自主開發RocketMQ等。

2、消息中間件的組成

2.1 Broker

消息服務器,作為server提供消息核心服務

2.2 Producer

消息生產者,業務的發起方,負責生產消息傳輸給broker,

2.3 Consumer

消息消費者,業務的處理方,負責從broker獲取消息並進行業務邏輯處理

2.4 Topic

2.5 Queue

2.6 Message

消息體,根據不同通信協議定義的固定格式進行編碼的數據包,來封裝業務數據,實現消息的傳輸

3 消息中間件模式分類

3.1 點對點

PTP點對點:使用queue作為通信載體

說明:

消息生產者生產消息發送到queue中,然後消息消費者從queue中取出並且消費消息。

消息被消費以後,queue中不再存儲,所以消息消費者不可能消費到已經被消費的消息。 Queue支持存在多個消費者,但是對壹個消息而言,只會有壹個消費者可以消費。

說明:

queue實現了負載均衡,將producer生產的消息發送到消息隊列中,由多個消費者消費。但壹個消息只能被壹個消費者接受,當沒有消費者可用時,這個消息會被保存直到有壹個可用的消費者。

4 消息中間件的優勢

4.1 系統解耦

交互系統之間沒有直接的調用關系,只是通過消息傳輸,故系統侵入性不強,耦合度低。

4.2 提高系統響應時間

例如原來的壹套邏輯,完成支付可能涉及先修改訂單狀態、計算會員積分、通知物流配送幾個邏輯才能完成;通過MQ架構設計,就可將緊急重要(需要立刻響應)的業務放到該調用方法中,響應要求不高的使用消息隊列,放到MQ隊列中,供消費者處理。

4.3 為大數據處理架構提供服務

通過消息作為整合,大數據的背景下,消息隊列還與實時處理架構整合,為數據處理提供性能支持。

4.4 Java消息服務——JMS

Java消息服務(Java Message Service,JMS)應用程序接口是壹個Java平臺中關於面向消息中間件(MOM)的API,用於在兩個應用程序之間,或分布式系統中發送消息,進行異步通信。

5 消息中間件應用場景

5.1 異步通信

有些業務不想也不需要立即處理消息。消息隊列提供了異步處理機制,允許用戶把壹個消息放入隊列,但並不立即處理它。想向隊列中放入多少消息就放多少,然後在需要的時候再去處理它們。

5.2 解耦

降低工程間的強依賴程度,針對異構系統進行適配。在項目啟動之初來預測將來項目會碰到什麽需求,是極其困難的。通過消息系統在處理過程中間插入了壹個隱含的、基於數據的接口層,兩邊的處理過程都要實現這壹接口,當應用發生變化時,可以獨立的擴展或修改兩邊的處理過程,只要確保它們遵守同樣的接口約束。

5.3 冗余

有些情況下,處理數據的過程會失敗。除非數據被持久化,否則將造成丟失。消息隊列把數據進行持久化直到它們已經被完全處理,通過這壹方式規避了數據丟失風險。許多消息隊列所采用的”插入-獲取-刪除”範式中,在把壹個消息從隊列中刪除之前,需要妳的處理系統明確的指出該消息已經被處理完畢,從而確保妳的數據被安全的保存直到妳使用完畢。

5.4 擴展性

因為消息隊列解耦了妳的處理過程,所以增大消息入隊和處理的頻率是很容易的,只要另外增加處理過程即可。不需要改變代碼、不需要調節參數。便於分布式擴容。

5.5 過載保護

在訪問量劇增的情況下,應用仍然需要繼續發揮作用,但是這樣的突發流量無法提取預知;如果以為了能處理這類瞬間峰值訪問為標準來投入資源隨時待命無疑是巨大的浪費。使用消息隊列能夠使關鍵組件頂住突發的訪問壓力,而不會因為突發的超負荷的請求而完全崩潰。

5.6 可恢復性

系統的壹部分組件失效時,不會影響到整個系統。消息隊列降低了進程間的耦合度,所以即使壹個處理消息的進程掛掉,加入隊列中的消息仍然可以在系統恢復後被處理。

5.7 順序保證

在大多使用場景下,數據處理的順序都很重要。大部分消息隊列本來就是排序的,並且能保證數據會按照特定的順序來處理。

5.8 緩沖

在任何重要的系統中,都會有需要不同的處理時間的元素。消息隊列通過壹個緩沖層來幫助任務最高效率的執行,該緩沖有助於控制和優化數據流經過系統的速度。以調節系統響應時間。

5.9 數據流處理

分布式系統產生的海量數據流,如:業務日誌、監控數據、用戶行為等,針對這些數據流進行實時或批量采集匯總,然後進行大數據分析是當前互聯網的必備技術,通過消息隊列完成此類數據收集是最好的選擇。

6 消息中間件常用協議

6.1 AMQP協議

AMQP即Advanced Message Queuing Protocol,壹個提供統壹消息服務的應用層標準高級消息隊列協議,是應用層協議的壹個開放標準,為面向消息的中間件設計。基於此協議的客戶端與消息中間件可傳遞消息,並不受客戶端/中間件不同產品,不同開發語言等條件的限制。

優點:可靠、通用

6.2 MQTT協議

MQTT(Message Queuing Telemetry Transport,消息隊列遙測傳輸)是IBM開發的壹個即時通訊協議,有可能成為物聯網的重要組成部分。該協議支持所有平臺,幾乎可以把所有聯網物品和外部連接起來,被用來當做傳感器和致動器(比如通過Twitter讓房屋聯網)的通信協議。

優點:格式簡潔、占用帶寬小、移動端通信、PUSH、嵌入式系統

6.3 STOMP協議

STOMP(Streaming Text Orientated Message Protocol)是流文本定向消息協議,是壹種為MOM(Message Oriented Middleware,面向消息的中間件)設計的簡單文本協議。STOMP提供壹個可互操作的連接格式,允許客戶端與任意STOMP消息代理(Broker)進行交互。

優點:命令模式(非topic\queue模式)

6.4 XMPP協議

XMPP(可擴展消息處理現場協議,Extensible Messaging and Presence Protocol)是基於可擴展標記語言(XML)的協議,多用於即時消息(IM)以及在線現場探測。適用於服務器之間的準即時操作。核心是基於XML流傳輸,這個協議可能最終允許因特網用戶向因特網上的其他任何人發送即時消息,即使其操作系統和瀏覽器不同。

優點:通用公開、兼容性強、可擴展、安全性高,但XML編碼格式占用帶寬大

6.5 其他基於TCP/IP自定義的協議

有些特殊框架(如:redis、kafka、zeroMq等)根據自身需要未嚴格遵循MQ規範,而是基於TCP\IP自行封裝了壹套協議,通過網絡socket接口進行傳輸,實現了MQ的功能。

7 常見消息中間件MQ介紹

7.1 RocketMQ

阿裏系下開源的壹款分布式、隊列模型的消息中間件,原名Metaq,3.0版本名稱改為RocketMQ,是阿裏參照kafka設計思想使用java實現的壹套mq。同時將阿裏系內部多款mq產品(Notify、metaq)進行整合,只維護核心功能,去除了所有其他運行時依賴,保證核心功能最簡化,在此基礎上配合阿裏上述其他開源產品實現不同場景下mq的架構,目前主要多用於訂單交易系統。

具有以下特點:

官方提供了壹些不同於kafka的對比差異:

https://rocketmq.apache.org/docs/motivation/

7.2 RabbitMQ

使用Erlang編寫的壹個開源的消息隊列,本身支持很多的協議:AMQP,XMPP, SMTP,STOMP,也正是如此,使的它變的非常重量級,更適合於企業級的開發。同時實現了Broker架構,核心思想是生產者不會將消息直接發送給隊列,消息在發送給客戶端時先在中心隊列排隊。對路由(Routing),負載均衡(Load balance)、數據持久化都有很好的支持。多用於進行企業級的ESB整合。

7.3 ActiveMQ

Apache下的壹個子項目。使用Java完全支持JMS1.1和J2EE 1.4規範的 JMS Provider實現,少量代碼就可以高效地實現高級應用場景。可插拔的傳輸協議支持,比如:in-VM, TCP, SSL, NIO, UDP, multicast, JGroups and JXTA transports。RabbitMQ、ZeroMQ、ActiveMQ均支持常用的多種語言客戶端 C++、Java、.Net,、Python、 Php、 Ruby等。

7.4 Redis

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

7.5 Kafka

Apache下的壹個子項目,使用scala實現的壹個高性能分布式Publish/Subscribe消息隊列系統,具有以下特性:

7.6 ZeroMQ

號稱最快的消息隊列系統,專門為高吞吐量/低延遲的場景開發,在金融界的應用中經常使用,偏重於實時數據通信場景。ZMQ能夠實現RabbitMQ不擅長的高級/復雜的隊列,但是開發人員需要自己組合多種技術框架,開發成本高。因此ZeroMQ具有壹個獨特的非中間件的模式,更像壹個socket library,妳不需要安裝和運行壹個消息服務器或中間件,因為妳的應用程序本身就是使用ZeroMQ API完成邏輯服務的角色。但是ZeroMQ僅提供非持久性的隊列,如果down機,數據將會丟失。如:Twitter的Storm中使用ZeroMQ作為數據流的傳輸。

ZeroMQ套接字是與傳輸層無關的:ZeroMQ套接字對所有傳輸層協議定義了統壹的API接口。默認支持 進程內(inproc) ,進程間(IPC) ,多播,TCP協議,在不同的協議之間切換只要簡單的改變連接字符串的前綴。可以在任何時候以最小的代價從進程間的本地通信切換到分布式下的TCP通信。ZeroMQ在背後處理連接建立,斷開和重連邏輯。

特性:

二、主要消息中間件的比較

  • 上一篇:2023年鹹寧赤壁市公安局公開招聘警務輔助人員公告?
  • 下一篇:湖南省茶陵縣職業中等專業學校專業有哪些?專業介紹
  • copyright 2024編程學習大全網