找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 7828|回復: 0
打印 上一主題 下一主題
收起左側

Modbus DTU與服務端間的通訊協(xié)議

[復制鏈接]
跳轉到指定樓層
樓主
ID:398336 發(fā)表于 2018-9-15 15:26 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
一.數(shù)據(jù)幀格式
              為防止DTU和服務器傳輸過程中因網絡原因導致拆包、粘包,因此約定傳輸?shù)幕緮?shù)據(jù)幀格式如下,DTU上傳和服務器下發(fā)的數(shù)據(jù)包均需滿足此數(shù)據(jù)幀格式要求。服務器應解決TCP傳輸過程中的拆包粘包問題,確保每次處理的是完整的數(shù)據(jù)包。
              基本數(shù)據(jù)幀格式:
域名
Type
Length
Data[n]
CheckSum
長度(byte)
1
2
n
1
含義
包類型
包長
n個數(shù)據(jù)
校驗和
備注
決定了Data的內容
從Data到CheckSum的字節(jié)數(shù)。大端格式(高字節(jié)在前)

從Type開始按字節(jié)累加到本域的前一字節(jié).每次累加進位去掉。
Type:數(shù)據(jù)包類型,也理解為Command. 不同的Tyep其對應的Length大小可能不同,Data也有所區(qū)別。
Length:在此之后的數(shù)據(jù)長度。大端格式。
CheckSum:校驗和,雖然TCP傳輸協(xié)議本身已經有CRC校驗,但網絡傳輸路徑的復雜性仍然無法保證數(shù)據(jù)一定無誤,因此需要對每個數(shù)據(jù)幀(包)再進行簡單的校驗。

二.Login和LoginAck及其Data含義
DTU每次和服務器建立TCP連接后,首先必須先往服務器發(fā)Login命令,服務器根據(jù)業(yè)務需要判斷其合法性(鑒權),然后回復LoginAck命令。
傳輸方向
Type名稱
Type
含義
Data內容格式
(按順序排列,排在前面的先傳輸,大端格式)
上行
Login
0x12
DTU請求登陸服務器
PSN(uint32)|PASS(uint32)|PName(uchar[8])|CurVer(uint16)| CCID(char[20]) |
下行
LoginAck
0x12
服務器應答DTU登陸請求
Right(uchar)|FoTaFlag(uchar)|TickTime(uchar)|SendTestMode(uchar)|SendTestTime(uchar)|NewVer(uint16)|NewPort(uint16)|NewIP(uchar[4])|
PSN:DTU編碼.每個DTU都有唯一的產品序列號(或簡稱DTU編碼)。
PASS: DTU密碼。
              服務器建立PSN和PASS關系表,初始化情況下PASS為0,當DTU請求Login時,如果數(shù)據(jù)庫里PSN對應的PASS為0時,不需比對直接通過,并將DTU上傳的PASS值寫入數(shù)據(jù)庫中,下次DTU再登錄服務器時,因數(shù)據(jù)庫的PASS非0而需要比較DTU上傳的PASS和數(shù)據(jù)庫的PASS是否相同,不同則認為鑒權失敗。
PName:產品名稱,如HS121, 不夠8字節(jié)的后面補0.
CurVer:當前DTU應用版本號。
CCID:  SIM卡的ICCID號(20個字符)。
Right:服務器鑒權結果。
              Right=0xEA表示鑒權成功! 其他值均表示鑒權失敗。如果鑒權失敗,服務器應在發(fā)完這條響應數(shù)據(jù)包后主動關閉此TCP連接。
FoTaFlag:  空中升級配置標志:
              FoTaFlag =0--不支持空中升級;
              FoTaFlag =1--可手動空中升級;用戶通過串口或按鍵組合才能觸發(fā)觸發(fā)空中升級。
              FoTaFlag =2--可自動空中升級。DTU收到此信息后應馬上進入空中升級模式。
TickTime:上傳心跳時間間隔
SendTestMode:  數(shù)據(jù)上傳模式,可以選擇服務器查詢,或者DTU自動上傳。(目前此模式無效,只支持定時上傳)
              SendTestMode=0 :任何一個測量值發(fā)生變化終端馬上上傳,但上傳速度不大于SendTestTime              所設定的時間。如SendTestTime=3則最快上傳速度為3              秒一次。
              SendTestMode =255:忽略Test值是否有變化,只按照SendTestTime設定的時間間隔上傳。
              SendTestMode=x( 0<x<255):當?shù)?~x個Test參數(shù)中有任何一個變化時馬上上傳,否則將根據(jù)SendTestTime所設定的時間定時上傳. Test測量值順序按終端和服務器約定的SendTest命令中Data的TestValue順序排列,2字節(jié)一組(組成unsigned short 或short類型數(shù)據(jù))。
SendTestTime: DTU上傳Test時間,在沒有服務端下發(fā)查詢的時候DTU以此時間間隔上傳DTU保存值,為0時表示不自動上傳。
NewVer:表示當前DTU軟件的最新版本號,0表示沒有新版本。當DTU檢查到當前版本小于最新版本時,DTU根據(jù)FoTaFlag決定是否遠程升級。
NewPort:新服務器端口。
NewIP:新服務器端IP地址。如123.86.55.33 第一個字節(jié)為123 按此順序。
                            NewPort和NewIP 可用于服務器遷移和負載均衡需要。為0時終端不處理,非0時終端將更新存儲的服務器IP和Port,下次鏈接服務器將用新的IP和Port.
三、SendTick和SendTickAck及其Data含義:
              DTU Login到服務器時,服務器下發(fā)的LoginAck中包含了TickTime參數(shù)(單位為秒),其值代表了DTU應該至少在多長時間內發(fā)起一次上行數(shù)據(jù),如果在這個時間段內沒有任何上行數(shù)據(jù)傳輸(如SendTest或SendSetup),則必須發(fā)一個SendTick 數(shù)據(jù)包到服務器,以便服務器持續(xù)保持TCP鏈路。
傳輸方向
Type名稱
Type
含義
Data內容格式

上行
SendTick
0x13
DTU上傳心跳包
下行
SendTickAck
0x13
服務器回應心跳
四. SaveSetup和SaveSetupAck及其相關的Data含義:
SaveSetup用于服務器配置自動上傳數(shù)據(jù)的時間間隔,以及DTU里關于寄存器地址的信息列表,即“寄存器列表”,DTU將根據(jù)此列表讀取對應寄存器地址的值(value)。配置成功后DTU用SaveSetupAck包把所配置的寄存器列表返回給服務器,可供服務器用于校驗配置成功與否。
傳輸方向
Type名稱
Type
含義
Data內容格式
(按順序排列,排在前面的先傳輸,大端格式)
下行
SaveSetup
0x16
服務器配置DTU的地址列表
SendTestTime(uchar)| SetDev1(uchar)|SetAddr1 (int16)|SetDev2(uchar)| SetAddr2(int16)|...
上行
SaveSetupAck
0x16
DTU響應服務器
Result(uchar)|SendTestTimeAck(uchar)|SetDevAck1(uchar)|SetAddrAck1 (int16)|SetDevAck2(uchar)| SetAddrAck2(int16)|...




寄存器地址列表:
從機號(uchar)
寄存器地址(int16)
1
0x55
1
0x56
1
0x57
2
0x55
...
...
下行SaveSetup:
SendTestTime:配置自動上傳數(shù)據(jù)的時間間隔(單位:秒)
SetDev1,SetAddr1從機號,寄存器地址
SetDev2,SetAddr2從機號,寄存器地址
SetDev3,SetAddr3從機號,寄存器地址
SetDev4,SetAddr4從機號,寄存器地址
SetDev5SetAddr5從機號,寄存器地址
......
上行SaveSetupAck:
成功返回:
Result1
SendTestTimeAck: 自動上傳數(shù)據(jù)的時間間隔(單位:秒)
SetDevAck1,SetAddrAck1從機號,寄存器地址
SetDevAck2,SetAddrAck2從機號,寄存器地址
SetDevAck3,SetAddrAck3從機號,寄存器地址
SetDevAck4,SetAddrAck4從機號,寄存器地址
SetDevAck5,SetAddrAck5從機號,寄存器地址
......
失敗返回:
Result0
五. ReadSetup和ReadSetupAck及其相關的Data含義:
ReadSetup用于服務器讀取DTU里存儲的自動上傳時間間隔參數(shù),以及“寄存器列表”。
傳輸方向
Type名稱
Type
含義
Data內容格式
(按順序排列,排在前面的先傳輸,大端格式)
下行
ReadSetup
0x19
服務器配置DTU的地址列表
上行
ReadSetupAck
0x19
DTU響應服務器
SendTestTime (uchar)|ReadDev1(uchar)|ReadAddr1 (int16) | ReadDev2(uchar)|ReadAddr2(int16)|...
SendTestTime自動上傳時間間隔
ReadDev1,ReadAddr1從機號,寄存器地址
ReadDev2ReadAddr2從機號,寄存器地址
ReadDev3ReadAddr3從機號,寄存器地址
ReadDev4,ReadAddr4從機號,寄存器地址
ReadDev5,ReadAddr5從機號,寄存器地址
......



六、SendTest和SendTestAck及其相關的Data含義:
              SendTest是DTU定時自動上傳的數(shù)據(jù)包,數(shù)據(jù)內容為寄存器里的值(value)。DTU將根據(jù)“寄存器列表”去獲取從機的對應的寄存器里對應值(value),按順序排列為如Value1,Value2,Value3... 將所有測量數(shù)據(jù)一起打包成SendTest數(shù)據(jù)包上傳給服務器。
傳輸方向
Type名稱
Type
含義
Data內容格式
(按順序排列,排在前面的先傳輸,大端格式)
上行
SendTest
0x14
DTU上傳測量數(shù)據(jù)
NetState(uchar)|TestCode(uchar)|Value1(int16) | Value2(int16)...
下行
SendTestAck
0x14
服務器響應DTU上傳測量數(shù)據(jù)
TestCode(uchar)
NetState: 網絡狀態(tài).DTU通訊模塊的CSQ值。
TestCode: 測量值標識碼。為了DTU同步Value數(shù)據(jù)到服務器,服務器收到SendTest數(shù)據(jù)包并成功解析、存儲后將此TestCode回傳給DTU。
              當DTU本地的各種Value發(fā)生變化且滿足SendTestMode要求時,本地記錄的TestCode加一(255加1等于0),然后和所有的Value打包成SendTest數(shù)據(jù)包上傳給服務器,當服務器收到SendTest數(shù)據(jù)包且成功解析并保存后將其值返回給DTU即可,假如服務器收到的SendTest數(shù)據(jù)包和事先約定的數(shù)據(jù)包不相符(比如個數(shù)少了),則服務器可以通過將TestCode減一(0減1等于255)后再回傳給DTU,這樣DTU會觸發(fā)重傳。TestCode服務器不需要保存在數(shù)據(jù)庫中。
Value1 : 第一個寄存器地址里的值;
Value2 : 第二個寄存器地址里的值;
Value3 : 第三個寄存器地址里的值;
Value4 : 第四個寄存器地址里的值;
......
七.ReadTest和ReadTestACK及相關的Data含義
ResdTest用于服務器查詢指定寄存器的數(shù)據(jù)。
ResdTestAck是DTU返回給服務器的數(shù)據(jù)包,由對應的寄存器的值(value)組成。
傳輸方向
Type名稱
Type
含義
Data內容格式
(按順序排列,排在前面的先傳輸,大端格式)
下行
ResdTest
0x18
服務器查詢DTU
ReadValueDev1(uchar)|ReadValueAddr1 (int16)|ReadValueDev2(uchar)| ReadValueAddr2(int16)|...
上行
ResdTestAck
0x18
DTU響應服務器查詢
Result(uchar)|ReadValue1(int16)| ReadValue12(int16)......
上行ResdTest:
ReadValueDev1,ReadValueAddr1從機號,寄存器地址
ReadValueDev2,ReadValueAddr2從機號,寄存器地址
ReadValueDev3,ReadValueAddr3從機號,寄存器地址
ReadValueDev4ReadValueAddr4從機號,寄存器地址
ReadValueDev5,ReadValueAddr5從機號,寄存器地址
......

下行ResdTestAck:
成功返回:
Result1
ReadValue1: 第一個寄存器地址里的值
ReadValue2: 第一個寄存器地址里的值
ReadValue3: 第一個寄存器地址里的值
ReadValue4: 第一個寄存器地址里的值
ReadValue5: 第一個寄存器地址里的值
......
失敗返回:
Result0
八. SetControl和SetControl Ack及相關的Data含義
從機中,某些寄存器是用于配置的。SetControl用于服務器給DTU下發(fā)指令,讓DTU去設置某些寄存器的參數(shù). SetControlAck為DTU響應服務器的數(shù)據(jù)包,跟服務器下發(fā)的配置參數(shù)一致,可供服務器校驗配置成功與否。
傳輸方向
Type名稱
Type
含義
Data內容格式
(按順序排列,排在前面的先傳輸,大端格式)
下行
SetControl
0x17
服務器控制DTU
SetValueDev1 (uchar) |SetValueAddr 1(int16)| SetValue(int16)1| SetValueDev2 (uchar) |SetValueAddr 2(int16)| SetValue(int16)2|......
上行
SetControlAck
0x17
DTU響應服務器
Result(uchar)|SetValueDevAck1 (uchar)|SetValueAddrAck1 (int16)| SetValueAck1 (int16) |SetValueDevAck2 (uchar)|SetValueAddrAck2 (int16)| SetValueAck2 (int16)|......
下行SetControl:
SetValueDev1:              從機號
SetValueAddr1寄存器地址
SetValue1參數(shù)
SetValueDev2:              從機號
SetValueAddr2寄存器地址
SetValue2參數(shù)
......

上行SetControlAck:
成功返回:
Result1
SetValueDevAck1:              從機號
SetValueAddrAck1寄存器地址
SetValueAck1參數(shù)
SetValueDevAck2:              從機號
SetValueAddrAck2寄存器地址
SetValueAck2參數(shù)
......

失敗返回:
Result:0

附:
DTUDTU內的寄存器列地址和寄存器值列表示意:
從機號(uchar)
寄存器地址(int16)
值(int16)
1
0x33
0x12
1
0x34
0x34
1
0x55
0x56
1
0x56
0x78
1
0x57
0x90
2
0x55
0x12
2
0x88
0x12


完整的Word格式文檔51黑下載地址:
Modbus DTU與服務端間的通訊協(xié)議20170523.docx (27.71 KB, 下載次數(shù): 17)


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表