成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

大白話聊物聯(lián)網(wǎng)通信過程,看不懂算我輸!

物聯(lián)網(wǎng) 物聯(lián)網(wǎng)應(yīng)用
MQTT的服務(wù)器端管理著很多主題(topic),發(fā)布者是指對某個主題發(fā)布消息,訂閱者是指訂閱不同的主題。

[[427527]]

大家好,我是程序員小哈,十一假期結(jié)束了,我們繼續(xù)分享嵌入式相關(guān)知識,喜歡的小伙伴,文末點贊,讓我看到哈。

上一篇網(wǎng)文 與OneNET服務(wù)器連接初體驗 我們介紹了使用 MQTT.fx 軟件連接上OneNET服務(wù)器。

今天我們來看一下,MQTT客戶端如何與OneNET服務(wù)器進行數(shù)據(jù)通信,發(fā)布者(Publish)、代理(Broker)(服務(wù)器)、訂閱者(Subscribe)他們?nèi)咧g是什么樣的關(guān)系。

OneNET平臺的主題

MQTT的服務(wù)器端管理著很多主題(topic),發(fā)布者是指對某個主題發(fā)布消息,訂閱者是指訂閱不同的主題。

發(fā)布者和訂閱者都屬于客戶端,一個客戶端既可以是發(fā)布者,也可以是訂閱者。

發(fā)布者針對某個主題發(fā)布了一條消息至服務(wù)器,服務(wù)器會分發(fā)給所有訂閱了該主題的訂閱者。

因此定閱與發(fā)布必須要有主題,主題相當(dāng)于對發(fā)送給服務(wù)器端的消息進行了分類,只有客戶端定閱了某個主題后,才能收到相應(yīng)主題的payload,才能進行通信。

一個客戶端可以向服務(wù)器訂閱多個主題。

比如我們分享過的的綜合實例:基于ZigBee的智能家居 。

這里阿里云物聯(lián)網(wǎng)平臺就是MQTT的服務(wù)器(Broker),手機上的云智能APP和我們做的控制板就屬于客戶端。

手機控制電燈開關(guān),就是對設(shè)備屬性進行設(shè)置,手機APP端發(fā)布了一個控制燈動作的消息,控制板訂閱了這個消息,控制板就能收到服務(wù)器轉(zhuǎn)發(fā)來的這個消息,進而就能實現(xiàn)手機對控制板的控制。

控制板通過溫濕度傳感器獲取室內(nèi)的溫濕度信息,控制板通過發(fā)布帶有溫濕度信息的消息至服務(wù)器,手機端因為訂閱了此主題的消息,手機端也就可以收到此消息了,對此消息進行解析,進而顯示到手機APP中,也就實現(xiàn)了控制板上的溫濕度數(shù)據(jù)的上傳,這就是對設(shè)備屬性的上報。

參考官方的文檔,我們得知OneNET平臺的主題格式如下:

主題類型 請求topic 響應(yīng)topic
設(shè)備屬性上報 上行:$sys/{pid}/{device-name}/thing/property/post $sys/{pid}/{device-name}/thing/property/post/reply
設(shè)備屬性設(shè)置 下行:$sys/{pid}/{device-name}/thing/property/set $sys/{pid}/{device-name}/thing/property/set_reply
設(shè)備屬性獲取 下行:$sys/{pid}/{device-name}/thing/property/get $sys/{pid}/{device-name}/thing/property/get_reply
設(shè)備事件上報 上行:$sys/{pid}/{device-name}/thing/event/post $sys/{pid}/{device-name}/thing/event/post/reply

其中, {pid} 由產(chǎn)品ID替換,我們上文創(chuàng)建的產(chǎn)品ID為:hg8zt6E3LP。{device-name} 設(shè)備名稱為:XiaoHaLED 。

下面我們使用 MQTT.fx 軟件充當(dāng)客戶端,與OneNET服務(wù)器進行通信,我們看看如何發(fā)布和訂閱消息。

發(fā)布消息

MQTT傳輸?shù)南⒎譃椋褐黝}(topic--區(qū)分不同消息)和負(fù)載(payload--消息內(nèi)容)兩部分。

通過上面我們知道,如果設(shè)備的屬性要上報給服務(wù)器,那么其主題為:$sys/{pid}/{device-name}/thing/property/post

替換產(chǎn)品ID和設(shè)備名稱之后為:$sys/hg8zt6E3LP/XiaoHaLED/thing/property/post

  1.   "id""123"
  2.   "version""1.0"
  3.   "params": { 
  4.     "Runtime": { 
  5.       "value": 1000 
  6.     } 
  7.   } 

使用 MQTT.fx 軟件實現(xiàn)設(shè)備屬性上報,具體操作如下:

也可以同時改變多個參數(shù):

  1.  "id""123"
  2.  "version""1.0"
  3.  "params": { 
  4.   "Runtime": { 
  5.    "value": 1000 
  6.   }, 
  7.   "PowerSwitch": { 
  8.    "value"true 
  9.   } 
  10.  } 

使用 MQTT.fx 軟件實現(xiàn)設(shè)備多屬性上報,具體操作如下:

發(fā)布消息需要填寫 topic、payload和消息的服務(wù)質(zhì)量等級。

MQTT.fx軟件右側(cè)的 QoS0、 QoS1等是消息服務(wù)質(zhì)量等級。

MQTT協(xié)議中有三種消息發(fā)布服務(wù)質(zhì)量:

QoS0:“至多一次”,消息發(fā)布完全依賴底層 TCP/IP 網(wǎng)絡(luò)。會發(fā)生消息丟失或重復(fù)的情況。此級別一般用于環(huán)境傳感器數(shù)據(jù)上傳,即使丟失一次數(shù)據(jù)也無所謂,因為一般傳感器數(shù)據(jù)的上傳都是周期性的。

QoS1:“至少一次”,確保消息到達(dá),但消息重復(fù)可能會發(fā)生。

QoS2:“只有一次”,確保消息到達(dá)一次。這一級別可用于對消息丟失和重復(fù)不能容忍的場景,比如在計費系統(tǒng)中,此服務(wù)質(zhì)量的消息因為系統(tǒng)開銷大,一般物聯(lián)網(wǎng)平臺都是不支持的。

OneNET平臺對協(xié)議特性支持如下:

MQTT的訂閱

通常客戶端與MQTT Broker建立連接之后,客戶端首先要對其感興趣的主題進行一下訂閱。

比如設(shè)備屬性設(shè)置,下行:$sys/{pid}/{device-name}/thing/property/set

替換產(chǎn)品ID和設(shè)備名稱之后為:$sys/hg8zt6E3LP/XiaoHaLED/thing/property/set

下面演示一下,使用MQTT.fx軟件訂閱設(shè)備屬性設(shè)置的主題,然后使用OneNET控制臺中的應(yīng)用模擬器(模擬一個客戶端),當(dāng)其改變某個屬性的時候,MQTT.fx軟件會同步收到此主題的消息內(nèi)容,對此消息進行解析,就可以知道對設(shè)備屬性設(shè)置的指令的具體內(nèi)容了。

總結(jié)

本文介紹了 MQTT協(xié)議 ,MQTT協(xié)議采用發(fā)布/訂閱(Publish/Subscribe)模式,該協(xié)議主要有三個角色:發(fā)布者(Publish)、代理(Broker)(服務(wù)器)、訂閱者(Subscribe)。

他們?nèi)叩年P(guān)系如下圖所示:

由上圖我們可以看出來,消息傳遞的時候,并不是從消息的發(fā)布方直接送達(dá)到訂閱端,而是經(jīng)過 MQTT Broker 進行消息的分發(fā)。

這種發(fā)布/訂閱消息模式,提供了一種一對多的消息分發(fā)機制,進而實現(xiàn)了應(yīng)用程序的解耦。

發(fā)布者(Publish) 是發(fā)送消息的一方,可以為一個應(yīng)用程序或一臺設(shè)備。

代理(Broker)(服務(wù)器) 是管理消息隊列的一方,位于消息發(fā)布者和訂閱者之間。云端(服務(wù)器端)通過主題(Topic)的方式管理各個物聯(lián)網(wǎng)設(shè)備的訂閱,實現(xiàn)將設(shè)備與設(shè)備之間消息進行轉(zhuǎn)發(fā)。

訂閱者(Subscribe) 是訂閱主題的一方,主要用于接收消息。 

怎么樣?通過上面的描述,物聯(lián)網(wǎng)的通信過程你明白了嗎?

本文轉(zhuǎn)載自微信公眾號「嵌入式從0到1」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系嵌入式從0到1公眾號。

 

責(zé)任編輯:武曉燕 來源: 嵌入式從0到1
相關(guān)推薦

2020-02-04 15:00:25

大白話認(rèn)識JVM

2021-02-18 09:06:39

數(shù)據(jù)訪問者模式

2023-12-26 18:22:05

RocketMQ延遲消息

2018-08-03 18:15:40

物聯(lián)網(wǎng)通信架構(gòu)IOT

2018-06-11 23:34:42

2019-08-14 09:13:38

中臺互聯(lián)網(wǎng)業(yè)務(wù)

2021-01-12 09:47:14

物聯(lián)網(wǎng) 通信技術(shù)通訊技術(shù)

2021-09-01 11:18:33

物聯(lián)網(wǎng)窄帶物聯(lián)網(wǎng)IoT

2020-02-20 11:32:09

Kafka概念問題

2024-01-23 12:47:27

2021-12-16 10:49:32

物聯(lián)網(wǎng)通信協(xié)議網(wǎng)絡(luò)

2020-06-01 14:15:57

物聯(lián)網(wǎng)通信協(xié)議無線通訊

2023-04-27 17:49:38

物聯(lián)網(wǎng)通信協(xié)議

2019-12-09 08:29:26

Netty架構(gòu)系統(tǒng)

2018-02-25 22:37:34

2019-05-17 08:27:23

SQL注入漏洞攻擊

2020-12-04 06:40:46

Zookeeper選舉機制

2018-12-07 13:58:38

物聯(lián)網(wǎng)通信協(xié)議IOT

2020-09-08 06:30:59

微服務(wù)代碼模塊

2024-12-09 08:18:33

點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 亚洲国产精品一区二区第一页 | 亚洲国产成人av好男人在线观看 | 国产欧美一区二区精品久导航 | 在线日韩欧美 | 日本h片在线观看 | 国产东北一级毛片 | 最新超碰 | 酒色成人网 | av在线一区二区三区 | 每日更新av | 精品久久一区 | 黑人巨大精品欧美黑白配亚洲 | 国产一区二区三区四区三区四 | 综合一区二区三区 | 亚洲视频在线观看一区二区三区 | 久久精品国产99国产 | 国产精品久久一区 | 日本一二区视频 | 精品久久久久久亚洲精品 | 日本在线一区二区三区 | 男女羞羞视频在线 | 欧美精品一级 | 91精品国产综合久久久久久丝袜 | 日韩一区二区三区四区五区六区 | 亚洲一区精品在线 | 激情小视频| caoporn视频在线 | 国产999在线观看 | 日韩在线精品强乱中文字幕 | 国内精品免费久久久久软件老师 | 午夜视频一区 | 亚洲成av人片在线观看无码 | 国产精品久久久久无码av | 国产成人午夜高潮毛片 | 精品国产伦一区二区三区观看说明 | 天天操天天操 | 97精品久久 | 国产精品178页 | 中文字幕蜜臀av | 国产av毛片 | 男女网站视频 |