你好,我是Modbus TCP協(xié)議
大家好,我是Modbus-TCP協(xié)議。前面的文章,我大哥(Modbus-RTU協(xié)議)曾做過自我介紹(原文網(wǎng)址:https://www.founderchip.com/?id=65),今天這篇文章,我也想和大家認識下。

封面圖片來自https://pixabay.com并做了適當修改,原圖片由mohamed Hassan在Pixabay上發(fā)布,感謝作者。
我來自Modbus大家庭,我們家有三個兄弟:大哥(Modbus-RTU協(xié)議)、二哥(Modbus-ASCII協(xié)議)和我,我們都活躍在工業(yè)通信領(lǐng)域。我大哥和二哥擅長串行通信,比如基于RS485或者RS232的通信,而我則擅長基于以太網(wǎng)的通信。由于底層所使用的結(jié)構(gòu)不同,我們的應用數(shù)據(jù)單元(Application Data Unit,ADU)有所不同。你可能并去清楚什么是ADU,我來詳細介紹下吧。
為了進行通信,我們家規(guī)定了一種很簡單的數(shù)據(jù)結(jié)構(gòu),被稱為"協(xié)議數(shù)據(jù)單元"(Protocol Data Unit,PDU)。
協(xié)議數(shù)據(jù)單元由功能碼+數(shù)據(jù)構(gòu)成,如下面這張圖:

功能碼的長度為1個字節(jié),它表示要執(zhí)行的功能。比如常見的:01讀取線圈;02讀取離散量輸入值;03讀取保持寄存器值;05寫單個線圈等;
數(shù)據(jù)部分的長度為0~252個字節(jié),它表示要讀的地址或者要寫入的值,不同的功能碼對應的數(shù)據(jù)有所不同。比如01功能碼,其數(shù)據(jù)為4個字節(jié),其中前兩個字節(jié)表示要讀取的線圈的地址,后兩個字節(jié)表示要讀取線圈的數(shù)量;而對于05功能碼,其數(shù)據(jù)也是4個字節(jié),前兩個字節(jié)表示要寫入線圈的地址,后面兩字節(jié)表示要寫入的值。
協(xié)議數(shù)據(jù)單元有三種類型:請求型協(xié)議數(shù)據(jù)單元(Request PDU)、應答型協(xié)議數(shù)據(jù)單元(Response PDU)、及異常應答型協(xié)議數(shù)據(jù)單元(Exception Response PDU),更多關(guān)于協(xié)議數(shù)據(jù)單元的內(nèi)容,你可以去我家官網(wǎng)(http://modbus.org)下載通信規(guī)范好好閱讀下,或者去北島李工的網(wǎng)站(https://www.founderchip.com)下載。
協(xié)議數(shù)據(jù)單元是我們家族的通用數(shù)據(jù)結(jié)構(gòu),它與底層物理結(jié)構(gòu)無關(guān),我們?nèi)值芏际褂孟嗤膮f(xié)議數(shù)據(jù)單元。但是,我們在通信的時候,總要依賴物理網(wǎng)絡(luò)。因此要把協(xié)議數(shù)據(jù)單元映射到物理網(wǎng)絡(luò)上,這就形成了應用數(shù)據(jù)單元(Application Data Unit,ADU)。由于底層網(wǎng)絡(luò)的不同,我跟兩個哥哥的應用數(shù)據(jù)單元是不同的,他們的ADU結(jié)構(gòu)如下圖所示:

而我的ADU結(jié)構(gòu)如下:

可以看到,我的應用數(shù)據(jù)單元是在協(xié)議數(shù)據(jù)單元的基礎(chǔ)上,添加了一個叫做"MBAP頭(MBAP Header)"的結(jié)構(gòu)。MBAP是英文"ModBus APlication"的縮寫,即"應用數(shù)據(jù)單元"的意思。
MBAP頭結(jié)構(gòu)由7個字節(jié)構(gòu)成,如下表所示:

其中:
-
傳輸標識符:用于標識應用數(shù)據(jù)單元,即請求和應答之間的配對;客戶端對該部分進行初始化,服務(wù)器端將其拷貝到自己的ADU中;
-
協(xié)議標識符:系統(tǒng)間的協(xié)議標識,0=Modbus;
-
長度:接下來要發(fā)送的數(shù)據(jù)長度,即:單元標識符+PDU的總長度,以字節(jié)為單位;
-
單元標識符:用于系統(tǒng)間的站尋址,比如在以太網(wǎng)+串行鏈路的網(wǎng)絡(luò)中,遠程站的地址;
這就是我的ADU結(jié)構(gòu),即:MBAP頭+PDU,是不是很簡單呢?我的數(shù)據(jù)傳輸采用的是一種被稱為"客戶端/服務(wù)器"的模式,這也是上面的表格中會出現(xiàn)客戶端/服務(wù)器功能描述的原因。其實,很多網(wǎng)絡(luò)通信都采用的這種方式,比如大名鼎鼎的西門子的S7通信協(xié)議。在串行鏈路中,這種方式也稱為主-從通信。
說道這里,你可能會有一個疑惑。因為我們在網(wǎng)絡(luò)通信中,通常需要寫明IP地址和端口號,為什么我的ADU中沒有相關(guān)的內(nèi)容呢?
哈哈,其實這是因為我是一個應用層的協(xié)議,而你說的IP地址和端口號屬于傳輸層/網(wǎng)絡(luò)層的協(xié)議。還沒明白,好吧,看看這張圖:

你看,在邏輯上我是在TCP層上的。在發(fā)送數(shù)據(jù)的時候,我的應用數(shù)據(jù)單元首先向下傳送給傳輸層,加上TCP協(xié)議的報文;再傳送給網(wǎng)絡(luò)層,加上IP協(xié)議的報文;再向下傳送給數(shù)據(jù)鏈路層及物理層;接收的過程正好相反,從物理層一層一層的去掉相應層的報文,最終到達應用層。所以在使用我進行數(shù)據(jù)傳輸?shù)臅r候,是要配合TCP/IP協(xié)議來使用的。通常如果你使用電腦編程,就要用到SOCKET技術(shù);如果是使用PLC編程,通常廠家已經(jīng)把底層通信封裝成庫指令了,你只要直接調(diào)用就好了。比如西門子S7-200 SMART/1200/1500等PLC都有現(xiàn)成的Modbus-TCP指令庫。
-
神器:5秒鐘搞定贗電容k1擬合、繪圖、計算電容貢獻率 2020-06-25
-
化工設(shè)計之工程圖紙(這篇文章給你講全了) 2020-07-03
-
工具:贗電容k1Tool-v2.6解決擬合交叉問題 2020-06-25
-
斷續(xù)焊焊接符號 2021-10-14
-
板式塔設(shè)計核心:負荷性能圖(水力學圖) 2020-07-03
-
應急管理部已明確:臨時性登高作業(yè)屬于特種作業(yè)!需要取證 2021-10-18
-
PDMS12.1sp4安裝教程 2020-07-03
-
話說LED燈的利用系數(shù) 2020-07-04
-
一張圖講清楚斷路器的工作原理 2020-07-10
-
引起管道振動的主要原因及消振措施 2020-12-06
