99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

你了解清楚了嘛-TCP、HTTP、MQTT協(xié)議

IOTRouter ? 來源:IOTRouter ? 作者:IOTRouter ? 2024-07-11 11:34 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

如下參考于成都縱橫智控-https://www.iotrouter.com/news/2009.html 或(蘇州穩(wěn)聯(lián))

物聯(lián)網(wǎng)(IoT)的快速發(fā)展離不開數(shù)據(jù)傳輸技術的進步。在眾多的數(shù)據(jù)傳輸協(xié)議中,TCP、HTTP、和MQTT各有其獨特的優(yōu)勢和應用場景。本文將詳細解析這三種協(xié)議的特點、應用及其相互之間的區(qū)別,以幫助開發(fā)者在不同的物聯(lián)網(wǎng)應用中選擇最合適的傳輸協(xié)議。
依據(jù)OSI網(wǎng)絡分層模型,TCP屬于傳輸層協(xié)議,HTTP和MQTT屬于應用層協(xié)議。TCP是HTTP和MQTT的底層協(xié)議。

wKgaomaM8TaAQTxWAACIZqMj3-A546.png

TCP、HTTP、MQTT協(xié)議


TCP:傳輸控制協(xié)議
TCP是一種基于連接的可靠傳輸協(xié)議。這是互聯(lián)網(wǎng)協(xié)議套件的一部分,用于在網(wǎng)絡中的2個運用中間建立一個靠譜的數(shù)據(jù)傳輸通道。TCP增強了數(shù)據(jù)分割、重組、流量管理和擁塞控制等業(yè)務,以確保數(shù)據(jù)的穩(wěn)定性和次序傳送。這是一項面對連接的協(xié)議,規(guī)定在傳輸數(shù)據(jù)以前建立一個連接。TCP適用文件傳送、電子郵箱和網(wǎng)頁瀏覽對傳輸數(shù)據(jù)可靠性要求高的運用。建立一個TCP連接需要三次握手,斷開一個TCP連接需要四次揮手。TCP協(xié)議可以對上層網(wǎng)絡提供接口,使上層網(wǎng)絡數(shù)據(jù)的傳輸建立在“無差別”的網(wǎng)絡之上。

1.三次握手:是TCP協(xié)議建立連接的過程,確保雙方都已準備好進行數(shù)據(jù)傳輸。以下是三次握手的步驟和示意圖:

步驟 描述 示意圖
1 客戶端發(fā)送SYN:客戶端向服務器發(fā)送一個SYN(同步序列編號)請求,以初始化連接。 wKgaomaM8teAHyxvAAASbNi7OaQ807.png
TCP:三次握手
2 服務器發(fā)送SYN-ACK:服務器收到SYN請求后,回復一個SYN-ACK(同步序列編號-確認)包,表示同意建立連接,并告知客戶端已收到其請求。
3 客戶端發(fā)送ACK:客戶端收到SYN-ACK后,再發(fā)送一個ACK(確認)包,表示確認連接已建立,雙方可以開始數(shù)據(jù)傳輸。

2.四次揮手:是TCP協(xié)議斷開連接的過程,確保雙方都已完成數(shù)據(jù)傳輸并同意斷開連接。以下是四次揮手的步驟及示意圖:

步驟 描述 示意圖
1 客戶端發(fā)送FIN:客戶端向服務器發(fā)送一個FIN(終止連接)請求,表示其已經(jīng)完成數(shù)據(jù)發(fā)送,準備斷開連接。 wKgaomaM8zqAb7mWAAANu8n_nFs314.png
TCP:四次揮手
2 服務器發(fā)送ACK:服務器收到FIN請求后,回復一個ACK(確認)包,表示已收到客戶端的斷開請求,但可能還有未完成的數(shù)據(jù)需要發(fā)送。
3 服務器發(fā)送FIN:服務器完成數(shù)據(jù)發(fā)送后,向客戶端發(fā)送一個FIN請求,表示其也準備斷開連接。
4 客戶端發(fā)送ACK:客戶端收到服務器的FIN請求后,回復一個ACK包,表示確認斷開連接,連接正式斷開。

HTTP:超文本傳輸協(xié)議
HTTP用于在Web上傳送超文本(如HTML)和其他資源應用層協(xié)議。TCP的穩(wěn)定性和連接性是根據(jù)TCP。HTTP挑選客戶端-服務器模型,客戶端向服務器推送HTTP規(guī)定,服務器回到HTTP回應,以傳送需要資源。HTTP是一種無狀態(tài)協(xié)議,每個請求和響應都是獨立的,服務器不會儲存客戶端狀態(tài)信息。

HTTP 請求/響應流程示意圖 HTTP 請求示例
wKgaomaM9AmAcwh_AAAUNdIUEkY951.png
HTTP 請求/響應流程示意圖
wKgaomaM9BaABB0GAAAwtc48aeg263.png
HTTP 請求示例

HTTP連接是一種“短連接”,由于HTTP在每個規(guī)定結(jié)束后都會主動釋放連接。為保持客戶端流程的在線狀態(tài),務必再次連接到服務器。一般來說,即便不用獲得所有數(shù)據(jù),客戶端還會每隔一段時間向服務器推送一次“維護連接”規(guī)定。服務器接到要求之后回復客戶端,表明客戶端是“線上”的。假如服務器長期接受不了客戶端的需求,但認為客戶端“撤出”,假如客戶端長期接受不了云服務器的回應,卻認為網(wǎng)絡已經(jīng)斷開。

MQTT:遠程傳輸消息隊列
MQTT是一種基于公示/定閱的MQTT(publish/subscribe)1999年IBM發(fā)布的TCP/IP協(xié)議中創(chuàng)立了該模式的“輕”通訊協(xié)議。MQTT最大的優(yōu)點是可以為連接遠程設備提供實時可靠的信息服務,編號少,帶寬有限。它作為一種低成本、低帶寬的即時通信協(xié)議,廣泛用于物聯(lián)網(wǎng)、小型機器和移動應用。

wKgZomaM9wSAI_OXAAA8Wmk2LRA867.png

以下是MQTT消息傳輸過程的示意圖:

1.客戶端連接到Broker:

CONNECT 請求:客戶端向MQTT Broker發(fā)起連接請求。
CONNACK 響應:Broker確認連接請求。

2.客戶端發(fā)布消息到主題:

PUBLISH 請求:客戶端將消息發(fā)布到特定主題。
Broker 將消息轉(zhuǎn)發(fā)給訂閱該主題的客戶端。

3.Broker 轉(zhuǎn)發(fā)消息:

PUBLISH 請求:Broker 將消息轉(zhuǎn)發(fā)給所有訂閱了該主題的客戶端。

4.客戶端確認消息接收:

PUBACK 響應:客戶端確認接收到消息,適用于QoS 1等級。

5.客戶端斷開連接:

DISCONNECT 請求:客戶端請求斷開與Broker的連接。
DISCONNECT 響應:Broker 確認斷開連接。

TCP、HTTP與MQTT的對比表格

特性 TCP HTTP MQTT
協(xié)議類型 傳輸層協(xié)議 應用層協(xié)議 應用層協(xié)議
連接建立 面向連接(三次握手) 無狀態(tài)請求-響應 面向連接(連接保持)
數(shù)據(jù)傳輸模式 可靠傳輸,順序保證 請求-響應 發(fā)布-訂閱
可靠性 取決于應用層實現(xiàn) 支持QoS等級確保可靠性
數(shù)據(jù)頭開銷 較大 較大 較小
傳輸效率 較低 中等
適用場景 可靠傳輸需求的場景 Web瀏覽、API通信、RESTful服務 物聯(lián)網(wǎng)、實時數(shù)據(jù)傳輸
典型應用 文件傳輸、電子郵件、遠程登錄 網(wǎng)頁瀏覽、Web API 物聯(lián)網(wǎng)設備通信、消息傳輸

總結(jié)

TCP、HTTP 和 MQTT 是三種不同層級和用途的協(xié)議是進行設備互聯(lián)和傳送數(shù)據(jù)的重要組成部分;TCP適用高可靠性傳送,HTTP適用Web服務與API打開,MQTT是物聯(lián)網(wǎng)設備通訊的不二之選。了解它們的特點和適用場景有助于在設計和實現(xiàn)網(wǎng)絡通信時做出最佳選擇。

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • HTTP
    +關注

    關注

    0

    文章

    525

    瀏覽量

    33492
  • TCP
    TCP
    +關注

    關注

    8

    文章

    1402

    瀏覽量

    81015
  • MQTT
    +關注

    關注

    5

    文章

    682

    瀏覽量

    23707
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    御控網(wǎng)關如何實現(xiàn)MQTT、MODBUS、OPCUA、SQL、HTTP之間協(xié)議轉(zhuǎn)換

    在工業(yè)自動化領域,不同設備、系統(tǒng)之間的通信協(xié)議就像不同的語言,常常讓信息交互變得困難重重。MQTT、MODBUS、OPCUA、SQL、HTTP協(xié)議各有特點,適用于不同的場景和設備,但
    的頭像 發(fā)表于 07-07 13:07 ?77次閱讀

    MQTT為何成為物聯(lián)網(wǎng)協(xié)議

    的優(yōu)勢,以下為詳細介紹: 輕量級特性,適配資源受限設備 協(xié)議頭開銷小 :MQTT協(xié)議頭非常簡潔,相比其他協(xié)議,它在數(shù)據(jù)傳輸時添加的額外信息
    的頭像 發(fā)表于 05-20 09:54 ?201次閱讀

    TCP協(xié)議的常見應用場景

    在現(xiàn)代通信網(wǎng)絡中,TCP協(xié)議因其可靠性和穩(wěn)定性而被廣泛應用于各種場景。 1. 網(wǎng)頁瀏覽 1.1 HTTP和HTTPS HTTP(超文本傳輸協(xié)議
    的頭像 發(fā)表于 01-22 09:55 ?2409次閱讀

    基于MQTT協(xié)議的車云通信設計

    Queuing Telemetry Transport)是由OASIS發(fā)布的應用層協(xié)議,采用訂閱/發(fā)布的通信模式,下層基于TCP/IP進行傳輸。該標準在工業(yè)物聯(lián)網(wǎng)、車聯(lián)網(wǎng)等領域有廣泛應用。 MQTT主要有以下
    的頭像 發(fā)表于 01-08 10:24 ?1042次閱讀
    基于<b class='flag-5'>MQTT</b><b class='flag-5'>協(xié)議</b>的車云通信設計

    如何使用 cURL 測試 HTTP 協(xié)議

    cURL是一個強大的命令行工具,用于傳輸數(shù)據(jù),支持多種協(xié)議,包括HTTP、HTTPS、FTP等。使用cURL測試HTTP協(xié)議可以幫助你理解HTTP
    的頭像 發(fā)表于 12-30 09:26 ?1089次閱讀

    HTTP 協(xié)議的工作原理

    HTTP協(xié)議的工作原理 1. HTTP協(xié)議概述 HTTP是一個應用層協(xié)議,它定義了客戶端與服務器
    的頭像 發(fā)表于 12-30 09:21 ?997次閱讀

    HTTP 協(xié)議的基本概念

    瀏覽器)和服務器之間請求和響應的格式。 1. HTTP協(xié)議概述 HTTP協(xié)議基于TCP/IP協(xié)議
    的頭像 發(fā)表于 12-29 15:12 ?1463次閱讀

    MQTT.fx 連接Onenet 多協(xié)議接入平臺 MQTT協(xié)議(舊版)詳解

    TCP dtu.heclouds.com 183.230.40.40 1811 打開Onenet平臺,多協(xié)議接入 選擇MQTT協(xié)議(舊版),點擊添加產(chǎn)品,輸入
    的頭像 發(fā)表于 09-30 15:20 ?1859次閱讀
    <b class='flag-5'>MQTT</b>.fx 連接Onenet 多<b class='flag-5'>協(xié)議</b>接入平臺 <b class='flag-5'>MQTT</b><b class='flag-5'>協(xié)議</b>(舊版)詳解

    物聯(lián)網(wǎng)行業(yè)中MQTT通信協(xié)議詳解以及使用

    ,該協(xié)議構(gòu)建于TCP/IP協(xié)議上,由IBM在1999年發(fā)布。 MQTT最大優(yōu)點在于, 用極少的代碼和有限的帶寬,為連接遠程設備提供實時可靠的消息服務 。 作為一種低開銷、低帶寬占用的即
    的頭像 發(fā)表于 09-20 17:08 ?2616次閱讀
    物聯(lián)網(wǎng)行業(yè)中<b class='flag-5'>MQTT</b>通信<b class='flag-5'>協(xié)議</b>詳解以及使用

    功能強大的網(wǎng)絡通訊工具,支持各類TCP、UDP、HTTP的通訊協(xié)議

    功能強大的網(wǎng)絡通訊工具,支持各類TCP、UDP、HTTP的通訊協(xié)議,簡單方便,包含歷史記憶功能,體積小,服務器調(diào)試最合適
    發(fā)表于 09-05 11:51 ?0次下載

    一文了解TCP/IP協(xié)議

    TCP/IP協(xié)議是現(xiàn)代計算機網(wǎng)絡通信的基礎,是互聯(lián)網(wǎng)及局域網(wǎng)廣泛使用的一套協(xié)議。TCP/IP協(xié)議集包括許多
    的頭像 發(fā)表于 08-07 15:38 ?3508次閱讀
    一文<b class='flag-5'>了解</b><b class='flag-5'>TCP</b>/IP<b class='flag-5'>協(xié)議</b>

    鋇錸技術Modbus轉(zhuǎn)MQTT網(wǎng)關:橋接Modbus協(xié)議MQTT協(xié)議

    提供了一鍵對接亞馬遜云平臺的解決方案。 BL101網(wǎng)關是鋇錸技術研發(fā)的一款高性能工業(yè)物聯(lián)網(wǎng)設備,通過橋接Modbus協(xié)議MQTT通信協(xié)議,實現(xiàn)了工業(yè)設備與云端平臺之間的高效互聯(lián)。支持Modbus RTU、Modbus
    的頭像 發(fā)表于 07-30 16:28 ?730次閱讀
    鋇錸技術Modbus轉(zhuǎn)<b class='flag-5'>MQTT</b>網(wǎng)關:橋接Modbus<b class='flag-5'>協(xié)議</b>與<b class='flag-5'>MQTT</b><b class='flag-5'>協(xié)議</b>

    基于MQTT協(xié)議云平臺的Modbus轉(zhuǎn)MQTT網(wǎng)關

    鋇錸Modbus轉(zhuǎn)MQTT網(wǎng)關BL100是一款高性能、高性價比的物聯(lián)網(wǎng)網(wǎng)關,它支持將Modbus協(xié)議(包括Modbus RTU和Modbus TCP)的數(shù)據(jù)轉(zhuǎn)換為MQTT
    的頭像 發(fā)表于 07-29 17:59 ?1133次閱讀
    基于<b class='flag-5'>MQTT</b><b class='flag-5'>協(xié)議</b>云平臺的Modbus轉(zhuǎn)<b class='flag-5'>MQTT</b>網(wǎng)關

    PLC協(xié)議、Modbus RTU TCP 、DL T645、IEC101-104、BACnet 轉(zhuǎn)Modbus TCP RTU、OPC UA、MQTT、BACnet IP協(xié)議網(wǎng)關

    /TP等多種協(xié)議轉(zhuǎn)換為Modbus TCP、OPC UA、MQTT、BACnet IP、華為云IoT、亞馬遜云IoT、阿里云IoT、ThingsBoard、Sparkplug B、鋇錸云等協(xié)議
    的頭像 發(fā)表于 07-24 16:04 ?1142次閱讀
    PLC<b class='flag-5'>協(xié)議</b>、Modbus RTU  <b class='flag-5'>TCP</b> 、DL T645、IEC101-104、BACnet 轉(zhuǎn)Modbus <b class='flag-5'>TCP</b> RTU、OPC UA、<b class='flag-5'>MQTT</b>、BACnet IP<b class='flag-5'>協(xié)議</b>網(wǎng)關

    Modbus RTU、Modbus TCP轉(zhuǎn)MQTT網(wǎng)關實現(xiàn)Modbus設備與云平臺的無縫通信

    鋇錸Modbus轉(zhuǎn)MQTT網(wǎng)關,簡而言之,就是通過將Modbus協(xié)議(包括Modbus RTU和Modbus TCP)的數(shù)據(jù)轉(zhuǎn)換為MQTT協(xié)議
    的頭像 發(fā)表于 07-23 16:58 ?4500次閱讀
    Modbus RTU、Modbus <b class='flag-5'>TCP</b>轉(zhuǎn)<b class='flag-5'>MQTT</b>網(wǎng)關實現(xiàn)Modbus設備與云平臺的無縫通信