<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 模擬技術(shù) > 設(shè)計應(yīng)用 > 無線物聯(lián)網(wǎng)中CoAP協(xié)議的研究與實現(xiàn)(一)

          無線物聯(lián)網(wǎng)中CoAP協(xié)議的研究與實現(xiàn)(一)

          作者: 時間:2013-10-09 來源:網(wǎng)絡(luò) 收藏
          ; TEXT-INDENT: 0px; PADDING-TOP: 0px; WHITE-SPACE: normal; LETTER-SPACING: normal; webkit-text-size-adjust: auto; orphans: 2; widows: 2; webkit-text-stroke-width: 0px">  (4)支持異步通信:HTTP對M2M(Machine-to-Machine)通信不適用,這是由于事務(wù)總是由客戶端發(fā)起。而支持異步通信,這對M2M通信應(yīng)用來說是常見的休眠/喚醒機(jī)制。

            (5)支持資源發(fā)現(xiàn):為了自主的發(fā)現(xiàn)和使用資源,它支持內(nèi)置的資源發(fā)現(xiàn)格式,用于發(fā)現(xiàn)設(shè)備上的資源列表,或者用于設(shè)備向服務(wù)目錄公告自己的資源。它支持RFC5785中的格式,在CoRE中用/.well—known/core的路徑表示資源描述。

           ?。?)支持緩存:支持資源描述的緩存以優(yōu)化其性能。

           ?。?)訂閱機(jī)制:CoAP使用異步通信方式,用訂閱機(jī)制實現(xiàn)從服務(wù)器到客戶端的消息推送。實現(xiàn)CoAP的發(fā)布,訂閱機(jī)制,它是請求成功后自動注冊的一種資源后處理程序。是由默認(rèn)的EVENT_和PERIODIC_RESOURCEs來進(jìn)行配置的。它們的事件和輪詢處理程序用 EST.notify_subscri bers()函數(shù)來發(fā)布。

            2.1 棧圖3是CoAP協(xié)議棧。CoAP協(xié)議的傳輸層使用UDP協(xié)議。由于UDP傳輸?shù)牟豢煽啃?,CoAP協(xié)議采用了雙層結(jié)構(gòu),定義了帶有重傳的事務(wù)處理機(jī)制,并且提供資源發(fā)現(xiàn)和資源描述等功能。CoAP采用盡可能小的載荷,從而限制了分片。

            無線物聯(lián)網(wǎng)中CoAP協(xié)議的研究與實現(xiàn)(一)

            事務(wù)層(Transaction layer)用于處理節(jié)點之間的信息交換,同時提供組播和擁塞控制等功能。請求/響應(yīng)層(Request/Responselayer)用于傳輸對資源進(jìn)行操作的請求和響應(yīng)信息。CoAP協(xié)議的REST構(gòu)架是基于該層的通信。CoAP的雙層處理方式,使得CoAP沒有采用TCP協(xié)議,也可以提供可靠的傳輸機(jī)制。利用默認(rèn)的定時器和指數(shù)增長的重傳間隔時間實現(xiàn)CON(Confirmable)消息的重傳,直到接收方發(fā)出確認(rèn)消息。另外,CoAP的雙層處理方式支持異步通信,這是和M2M應(yīng)用的關(guān)鍵需求之一。

            2.2 CoAP的訂閱機(jī)制HTTP的請求/響應(yīng)機(jī)制是假設(shè)事務(wù)都是由客戶端發(fā)起的,通常叫做拉模型。這導(dǎo)致客戶端不能高效的知統(tǒng)中,設(shè)備都是低功耗的,這些設(shè)備大部分時間是休眠狀態(tài),因此不能響應(yīng)輪詢請求。而CoRE認(rèn)為支持本地的推送模型是一個重要的需求,也就是由服務(wù)器初始化事務(wù)到客戶端。推送模型需要一個訂閱接口,用來請求響應(yīng)關(guān)于特定資源的改變。而由于UDP的傳輸是異步的,所以不需要特殊的通知消息。訂閱機(jī)制如圖4所示。

            無線物聯(lián)網(wǎng)中CoAP協(xié)議的研究與實現(xiàn)(一)

            2.3 CoAP的交互模型CoAP使用類似于HTTP的請求/響應(yīng)模型:CoAP終端節(jié)點作為客戶端向服務(wù)器發(fā)送一個或多個請求,服務(wù)器端回復(fù)客戶端的CoAP 請求。不同于HTTP,CoAP的請求和響應(yīng)在發(fā)送之前不需要事先建立連接,而是通過CoAP信息來進(jìn)行異步信息交換。CoAP協(xié)議使用UDP進(jìn)行傳輸。這是通過信息層選項的可靠性來實現(xiàn)的。CoAP定義了四種類型的信息:可證實的CON(Confirmable)信息,不可證實的NON(Non- Confirmable)信息,可確認(rèn)的ACK(Acknowledgement)信息和重置信息RST(Reset)。方法代碼和響應(yīng)代碼包含在這些信息中,實現(xiàn)請求和響應(yīng)功能。這四種類型信息對于請求/響應(yīng)的交互來說是透明的。

            CoAP的請求/響應(yīng)語義包含在CoAP信息中,其中分別包含方法代碼和響應(yīng)代碼。CoAP選項中包含可選的(或默認(rèn)的)請求和響應(yīng)信息,例如URI和負(fù)載內(nèi)容類型。令牌選項用于獨立匹配底層的請求到響應(yīng)信息。

            請求/響應(yīng)模型:請求包含在可證實的或不可證實的信息中,如果服務(wù)器端是立即可用的,它對請求的應(yīng)答包含在可證實的確認(rèn)信息中來進(jìn)行應(yīng)答。圖5是基本的 GET請求和響應(yīng)模式,其中圖5(a)表示成功發(fā)送請求和收到ACK確認(rèn)信息,圖5(b)表示重傳了請求信息,然后才收到ACK確認(rèn)信息。

            無線物聯(lián)網(wǎng)中CoAP協(xié)議的研究與實現(xiàn)(一)

            雖然CoAP協(xié)議目前還在制定當(dāng)中,但Contiki和TinyOS嵌入式操作系統(tǒng)已經(jīng)支持CoAP協(xié)議。Contiki是一個多任務(wù)操作系統(tǒng),并帶有 uIPv6協(xié)議棧,適用于嵌入式系統(tǒng)和傳感器網(wǎng)絡(luò),它占用系統(tǒng)資源小,適用于資源受限的網(wǎng)絡(luò)和設(shè)備。目前,火狐瀏覽器已經(jīng)集成了Copper插件,從而實現(xiàn)了CoAP協(xié)議。但是這種方式只能讀取傳感器節(jié)點上的實時數(shù)據(jù),而不能查看各種歷史數(shù)據(jù)。為此,在Contiki系統(tǒng)的基礎(chǔ)上,基于 uIPv6START KIT網(wǎng)絡(luò)開發(fā)套件,用自己編寫的客戶端程序?qū)崿F(xiàn)了和數(shù)據(jù)庫的交互,把歷史數(shù)據(jù)

          物聯(lián)網(wǎng)相關(guān)文章:物聯(lián)網(wǎng)是什么




          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();