MQTT 3.1.1,值得升級的6個(gè)新特性
前言
以前看英文文章或資料,看完之后,摘要或者忘記。這一次選擇感興趣的MQTT 3.1.1介紹文章資料,引文見文末,作為練手;非完全翻譯,去除掉一些廣告性描述,若侵權(quán),請告知。
在沉寂了四年之后,QTT 3.1.1規(guī)范于2014年10月30號正式發(fā)布,與此同時(shí)MQTT 3.1.1已成為OASIS(結(jié)構(gòu)化信息標(biāo)準(zhǔn)促進(jìn)組織)開放物聯(lián)網(wǎng)消息傳遞協(xié)議標(biāo)準(zhǔn)(連接1 連接2),換種說法就是MQTT 3.1.1已升級為國際物聯(lián)網(wǎng)標(biāo)準(zhǔn)。
正如HTTP為人們通過萬維網(wǎng)分享信息鋪平了道路一樣,MQTT能將幾十億低成本、嵌入式數(shù)據(jù)采集遙測設(shè)備連接到網(wǎng)絡(luò)。
與MQTT 3.1(還不是國際物聯(lián)網(wǎng)標(biāo)準(zhǔn)呢)規(guī)范相比,MQTT 3.1.1目標(biāo)在于消除歧義,盡可能的向后兼容,事實(shí)上一些大眾所需的新特性被包含在這個(gè)版本(更多的是物聯(lián)網(wǎng)標(biāo)準(zhǔn)推動),因此不僅是一個(gè)維護(hù)版本,也是一種巨大的進(jìn)步呢。除了概念的澄清和陳舊規(guī)范重寫外,有一些很有趣的變化是值得注意的。
會話表示標(biāo)志(Session Present Flag)
如果一個(gè)終端與服務(wù)器之間建立一個(gè)持久會話連接(假設(shè)這個(gè)終端沒有使用到一個(gè)“clean session”標(biāo)記清除已有回話標(biāo)志), 一個(gè)新增的“Session Present”標(biāo)志(會話表示標(biāo)志,邏輯值為true或false)會在CONNACK中出現(xiàn),表明MQTT服務(wù)器已經(jīng)擁有當(dāng)前客戶端上次連接會話信息,比如訂閱的主題,排隊(duì)信息和其它信息等。
會話表示標(biāo)志若為true,客戶端可減少了一次發(fā)送訂閱SUBSCRIBLE交互步驟,有助于更有效的數(shù)據(jù)通信;為false,客戶端需要再次發(fā)送訂閱SUBSCRIBLE消息,不可略過。
新增訂閱失敗代碼反饋
MQTT 3.1.1之前,終端連接之后無法知道其發(fā)送的訂閱主題是否被MQTT服務(wù)器接受與否。此新特性較適用于細(xì)粒度權(quán)限MQTT主題管理;若無授權(quán),服務(wù)器會把錯(cuò)誤代碼(0x80)附加在SUBACK中,客戶端就可以知道訂閱失敗。
MQTT匿名客戶端
需要支持臨時(shí)或匿名?客戶端僅僅需要在發(fā)送CONNECT時(shí)把客戶端標(biāo)識符( client identifier )置空(零長度)即可,MQTT服務(wù)器會為此類請求生成一個(gè)隨機(jī)、唯一客戶端標(biāo)記符。但這要求客戶端必須設(shè)置Clean Session標(biāo)記為1,否則服務(wù)器端會直接返回包含0x02 (Identifier rejected)代碼的CONNACK,同時(shí)關(guān)閉連接。
可用于后端程序(不需要維護(hù)回話狀態(tài))向終端發(fā)送消息的客戶端,MQTT服務(wù)器程序可區(qū)別對待。
快速發(fā)布無等待
這是一個(gè)新增的特別有用的特性,客戶端可以在發(fā)送CONNECT之后,可無須等待MQTT服務(wù)器返回的CONNACK,根據(jù)需要即刻發(fā)送PUBLISH、SUBSCRIBLE、DISCONNEECT等消息,可避免客戶端資源等待。此特性也適用于突發(fā)模式(burst-mode)客戶端需求,只關(guān)心數(shù)據(jù)要盡快的發(fā)送出去,而不是去擔(dān)心是否需要維護(hù)一個(gè)長連接。
這需要MQTT服務(wù)器實(shí)現(xiàn)在分發(fā)消息之前檢查客戶端是否有權(quán)限發(fā)布到這些主題上。
客戶端標(biāo)識符可以變長一些
MQTT 3.1針對客戶端標(biāo)識符( client identifier)限制是23個(gè)字節(jié),實(shí)際環(huán)境下會有所不便,已有遺留系統(tǒng)可能使用UUID作為客戶端的標(biāo)識符,這樣服務(wù)器端需要做一些彼此之間的MAP映射。 MQTT 3.1.1中上限為65535個(gè)字節(jié),畢竟成為業(yè)界標(biāo)準(zhǔn),需要兼容大量的遺留設(shè)備和基礎(chǔ)設(shè)施。
其它小改變
- CONNECT消息可變頭部協(xié)議名稱MQIsdp被改為MQTT,語義更準(zhǔn)確
- 所有字符串明確規(guī)定使用UTF-8編碼,包括客戶端標(biāo)識符(Client Identifier)
- CONNECT消息可變頭部協(xié)議版本號,由0x03變成了0x04 QoS 0類型PUBLISH消息DUP標(biāo)記必須被設(shè)置為0
- MQTT Over WebSocket 被定義,互聯(lián)網(wǎng)地址編碼分配機(jī)構(gòu)(Internet Assigned Numbers Authority)分配標(biāo)識符為mqtt。雖在MQTT 3.1規(guī)范通篇沒有提到WebSocket,但因其二進(jìn)制屬性可以很容易的在WebSocket通道傳輸。
術(shù)語變化
- MQTT代理 -> MQTT服務(wù)器(MQTT Broker is now MQTT Server)
- 消息ID -> 包ID(Message ID is now Packet ID)
- 消息類型 -> 包類型(Message Type is now Packet Type)
- 主題路徑 -> 主題名稱(Subscribe and Unsubscribe take Topic Paths, rather than Topic names)
- 以前在固定頭部,現(xiàn)在在包類型中( Flags in the fixed header are now specific to the packet type
- 0字節(jié)保留信息需要清除 (A zero byte retained message MUST NOT be stored as a retained message on the Server )
小結(jié)
當(dāng)前MQTT 3.1.1已經(jīng)在很多活躍開源項(xiàng)目/商業(yè)產(chǎn)品得到支持。比如Eclipse Paho,Mosquitto,JBoss A-MQ 6.1, Apache ActiveMQ 5.10-SNAPSHOT,Apache Camel 2.13.0,HiveMQ等。
關(guān)于Eclipse Paho:
- Eclipse Paho 1.0支持MQTT 3.1.1和MQTT 3.1規(guī)范
- Eclipse Paho 0.9僅支持 MQTT 3.1規(guī)范
包含MQTT 3.1.1和MQTT 3.1的客戶端可以混合使用,彼此可以共存于同一個(gè)MQTT服務(wù)器下,在基本消息傳輸層面沒有多大修改,同樣的PUBLISH消息可以在MQTT客戶端中自由流轉(zhuǎn),這個(gè)需要服務(wù)器端編碼支持。
已有的MQTT 3.1客戶端可以用著急升級,但升級之后可以從新增特性中收益良多。
引用
posted on 2014-12-16 13:59 nieyong 閱讀(23492) 評論(8) 編輯 收藏 所屬分類: MQTT