日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 物聯(lián)網(wǎng) > 物聯(lián)網(wǎng)技術(shù)文庫(kù)
[導(dǎo)讀]   消息傳遞作為基本通信機(jī)制已經(jīng)在全世界成功運(yùn)用。無(wú)論是人與人、機(jī)器與人還是機(jī)器與機(jī)器之間,消息傳遞一直都是唯一常用的通信方式。在雙方(或更多)之間交換消息有兩種基本機(jī)制。   同步消息

  消息傳遞作為基本通信機(jī)制已經(jīng)在全世界成功運(yùn)用。無(wú)論是人與人、機(jī)器與人還是機(jī)器與機(jī)器之間,消息傳遞一直都是唯一常用的通信方式。在雙方(或更多)之間交換消息有兩種基本機(jī)制。

  同步消息傳遞

  異步消息傳遞

  同步消息傳遞在這種情況下使用,當(dāng)消息發(fā)送者希望在某個(gè)時(shí)間范圍內(nèi)收到響應(yīng),然后再進(jìn)行下一個(gè)任務(wù)?;旧暇褪撬谑盏巾憫?yīng)前一直處于“阻塞”狀態(tài)。

  異步消息意味著發(fā)送者并不要求立即收到響應(yīng),而且也不會(huì)阻塞整個(gè)流程。響應(yīng)可有可無(wú),發(fā)送者總會(huì)執(zhí)行剩下的任務(wù)。

  上面提到的技術(shù),當(dāng)兩臺(tái)計(jì)算機(jī)上的程序相互通信的時(shí)候,就廣泛使用了異步消息傳遞。隨著微服務(wù)架構(gòu)的興起,很明顯我們需要使用異步消息傳遞模型來(lái)構(gòu)建服務(wù)。

  這一直是軟件工程中的基本問(wèn)題,而且不同的人和組織機(jī)構(gòu)會(huì)提出不同的方法。我將介紹在企業(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。

  

  圖片來(lái)源于網(wǎng)絡(luò)

  下面是JMS的主要特性:

  面向Java平臺(tái)的標(biāo)準(zhǔn)消息傳遞API

  在Java或JVM語(yǔ)言比如Scala、Groovy中具有互用性

  無(wú)需擔(dān)心底層協(xié)議

  有queues和topics兩種消息傳遞模型

  支持事務(wù)

  能夠定義消息格式(消息頭、屬性和內(nèi)容)

  高級(jí)消息隊(duì)列協(xié)議(Advanced Message Queueing Protocol (AMQP))

  JMS非常棒而且人們也非常樂(lè)意使用它。微軟開(kāi)發(fā)了NMS(.NET消息傳遞服務(wù))來(lái)支持他們的平臺(tái)和編程語(yǔ)言,它效果還不錯(cuò)。但是碰到了互用性的問(wèn)題。兩套使用兩種不同編程語(yǔ)言的程序如何通過(guò)它們的異步消息傳遞機(jī)制相互通信呢。此時(shí)就需要定義一個(gè)異步消息傳遞的通用標(biāo)準(zhǔn)。JMS或者NMS都沒(méi)有標(biāo)準(zhǔn)的底層協(xié)議。它們可以在任何底層協(xié)議上運(yùn)行,但是API是與編程語(yǔ)言綁定的。AMQP解決了這個(gè)問(wèn)題,它使用了一套標(biāo)準(zhǔn)的底層協(xié)議,加入了許多其他特征來(lái)支持互用性,為現(xiàn)代應(yīng)用豐富了消息傳遞需求。

  

  圖片來(lái)源于網(wǎng)絡(luò)

  下面是AMQP的主要特性:

  獨(dú)立于平臺(tái)的底層消息傳遞協(xié)議

  消費(fèi)者驅(qū)動(dòng)消息傳遞

  跨語(yǔ)言和平臺(tái)的互用性

  它是底層協(xié)議的

  有5種交換類型direct,fanout,topic,headers,system

  面向緩存的

  可實(shí)現(xiàn)高性能

  支持長(zhǎng)周期消息傳遞

  支持經(jīng)典的消息隊(duì)列,循環(huán),存儲(chǔ)和轉(zhuǎn)發(fā)

  支持事務(wù)(跨消息隊(duì)列)

  支持分布式事務(wù)(XA,X/OPEN,MS DTC)

  使用SASL和TLS確保安全性

  支持代理安全服務(wù)器

  元數(shù)據(jù)可以控制消息流

  不支持LVQ

  客戶端和服務(wù)端對(duì)等

  可擴(kuò)展

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀
關(guān)閉