異步消息傳遞技術(shù)JMS、AMQP和MQTT主要特性
消息傳遞作為基本通信機制已經(jīng)在全世界成功運用。無論是人與人、機器與人還是機器與機器之間,消息傳遞一直都是唯一常用的通信方式。在雙方(或更多)之間交換消息有兩種基本機制。
同步消息傳遞
異步消息傳遞
同步消息傳遞在這種情況下使用,當(dāng)消息發(fā)送者希望在某個時間范圍內(nèi)收到響應(yīng),然后再進行下一個任務(wù)?;旧暇褪撬谑盏巾憫?yīng)前一直處于“阻塞”狀態(tài)。
異步消息意味著發(fā)送者并不要求立即收到響應(yīng),而且也不會阻塞整個流程。響應(yīng)可有可無,發(fā)送者總會執(zhí)行剩下的任務(wù)。
上面提到的技術(shù),當(dāng)兩臺計算機上的程序相互通信的時候,就廣泛使用了異步消息傳遞。隨著微服務(wù)架構(gòu)的興起,很明顯我們需要使用異步消息傳遞模型來構(gòu)建服務(wù)。
這一直是軟件工程中的基本問題,而且不同的人和組織機構(gòu)會提出不同的方法。我將介紹在企業(yè)IT系統(tǒng)中廣泛使用的三種最成功的異步消息傳遞技術(shù)。
Java消息傳遞服務(wù)(Java Messaging Service (JMS))
JMS是最成功的異步消息傳遞技術(shù)之一。隨著Java在許多大型企業(yè)應(yīng)用中的使用,JMS就成為了企業(yè)系統(tǒng)的首選。它定義了構(gòu)建消息傳遞系統(tǒng)的API。
圖片來源于網(wǎng)絡(luò)
下面是JMS的主要特性:
面向Java平臺的標(biāo)準(zhǔn)消息傳遞API
在Java或JVM語言比如Scala、Groovy中具有互用性
無需擔(dān)心底層協(xié)議
有queues和topics兩種消息傳遞模型
支持事務(wù)
能夠定義消息格式(消息頭、屬性和內(nèi)容)
高級消息隊列協(xié)議(Advanced Message Queueing Protocol (AMQP))
JMS非常棒而且人們也非常樂意使用它。微軟開發(fā)了NMS(.NET消息傳遞服務(wù))來支持他們的平臺和編程語言,它效果還不錯。但是碰到了互用性的問題。兩套使用兩種不同編程語言的程序如何通過它們的異步消息傳遞機制相互通信呢。此時就需要定義一個異步消息傳遞的通用標(biāo)準(zhǔn)。JMS或者NMS都沒有標(biāo)準(zhǔn)的底層協(xié)議。它們可以在任何底層協(xié)議上運行,但是API是與編程語言綁定的。AMQP解決了這個問題,它使用了一套標(biāo)準(zhǔn)的底層協(xié)議,加入了許多其他特征來支持互用性,為現(xiàn)代應(yīng)用豐富了消息傳遞需求。
圖片來源于網(wǎng)絡(luò)
下面是AMQP的主要特性:
獨立于平臺的底層消息傳遞協(xié)議
消費者驅(qū)動消息傳遞
跨語言和平臺的互用性
它是底層協(xié)議的
有5種交換類型direct,fanout,topic,headers,system
面向緩存的
可實現(xiàn)高性能
支持長周期消息傳遞
支持經(jīng)典的消息隊列,循環(huán),存儲和轉(zhuǎn)發(fā)
支持事務(wù)(跨消息隊列)
支持分布式事務(wù)(XA,X/OPEN,MS DTC)
使用SASL和TLS確保安全性
支持代理安全服務(wù)器
元數(shù)據(jù)可以控制消息流
不支持LVQ
客戶端和服務(wù)端對等
可擴展