Difference between revisions of "Connectivity/AdvHeartBeat"
From ESS-WIKI
Eric.liang (talk | contribs) |
Eric.liang (talk | contribs) m (Reverted edits by Eric.liang (talk) to last revision by Winston) |
||
Line 1: | Line 1: | ||
− | < | + | =AdvHeartBeat Protocol= |
− | == | + | ==<span style="color:#0070c0;">AdvHeartBeat Topic & Payload</span>== |
− | + | Type: Response | |
− | + | Direction: Agent -> Server | |
− | + | Topic: /cagent/admin/<devID>/notify | |
− | + | QoS: 0 | |
+ | Retained: 0 | ||
+ | Payload: ~ 35 character | ||
+ | {"hb":{"devID":"0017000E40000001"}} | ||
− | == | + | ==<span style="color:#0070c0;">Client Site</span>== |
− | + | :Agent needs send "AdvHeartBeat" message ( refer to AdvHeartBeat Topic & Payload ) by period as below picture. | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | </ | ||
− | |||
− | == | ||
− | |||
− | :Agent needs send "AdvHeartBeat" message ( refer to AdvHeartBeat Topic & Payload ) by period as below picture. | ||
[[File:AdvHeartBeat-FC-1.jpg|500x400px|AdvHeartBeat Protocol]] | [[File:AdvHeartBeat-FC-1.jpg|500x400px|AdvHeartBeat Protocol]] | ||
− | == Server Site == | + | ==<span style="color:#0070c0;">Server Site</span>== |
− | |||
#Server would send "Get Capability" and "Change AdvHeartBeat sending rate" after receiving a "Connect Info" message. | #Server would send "Get Capability" and "Change AdvHeartBeat sending rate" after receiving a "Connect Info" message. | ||
#Server updates latest update time after receiving a AdvHeartBeat message with its AdvHeartBeat Table( NoSQL ). | #Server updates latest update time after receiving a AdvHeartBeat message with its AdvHeartBeat Table( NoSQL ). | ||
Line 32: | Line 23: | ||
##Server sends a re-connect message to this device. | ##Server sends a re-connect message to this device. | ||
− | == Re-Connect Message == | + | ==<span style="color:#0070c0;">Re-Connect Message</span>== |
− | |||
:If Server aware any problem of a device's status/information. Server will send a "Re-Connect" Message to Agent. Agent will send a "Connect Info" to Server after receiving a re-connect message. You can refer below for detail. | :If Server aware any problem of a device's status/information. Server will send a "Re-Connect" Message to Agent. Agent will send a "Connect Info" to Server after receiving a re-connect message. You can refer below for detail. | ||
[[File:AdvHeartBeat-FC-2.jpg|800x500px|AdvHeartBeat Protocol]] | [[File:AdvHeartBeat-FC-2.jpg|800x500px|AdvHeartBeat Protocol]] | ||
− | + | ||
− | Type: Request | + | Description: Server sends "Re-Connect" message for asking agent re-send its "Connect Info". |
− | Direction: Server -> Agent | + | Type: Request |
− | Topic: /cagent/admin/<devID>/agentcallbackreq | + | Direction: Server -> Agent |
− | QoS: 0 | + | Topic: /cagent/admin/<devID>/agentcallbackreq |
− | Retained: 0 | + | QoS: 0 |
− | Payload: | + | Retained: 0 |
− | { | + | Payload: |
+ | { | ||
+ | "susiCommData": { | ||
+ | "commCmd": 125, | ||
+ | "handlerName": "general", | ||
+ | "response": { | ||
+ | "statuscode": 4, | ||
+ | "msg": "Reconnect" | ||
+ | } | ||
+ | } | ||
+ | } | ||
+ | |||
+ | Description: Agent will send "Connect Info" after receiving a "Re-Connect" message. | ||
+ | Type: Response | ||
+ | Direction: Agent -> Server | ||
+ | Topic: /cagent/admin/<devID>/agentinfoack | ||
+ | QoS: 2 | ||
+ | Retained: 0 | ||
+ | Payload: | ||
+ | { | ||
"susiCommData": { | "susiCommData": { | ||
− | + | "devID":"0017000E40000001", | |
− | + | "hostname":"AAA", | |
− | + | "sn":"0017000E40000001", | |
− | + | "mac":"0017000E40000001", | |
− | + | "version":"3.1.23", | |
− | + | "type":"SenHub", | |
− | + | "product":"WISE-1020", | |
− | + | "manufacture":"", | |
− | + | "status":"1", | |
− | + | "commCmd":1, | |
− | + | "requestID":30002, | |
− | + | "agentID":"0017000E40000001", | |
− | + | "handlerName":"general", | |
− | + | "sendTS":160081026 | |
− | + | } | |
− | + | } | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | } | ||
− | |||
− | |||
− | |||
+ | ==<span style="color:#0070c0;">Connect Info</span>== | ||
Agent Client sends the "Connect Info" to Server for on-line notification. Server would send "Get Capability" to get capability of this agent device and "Change AdvHeartBeat rate" to sync with System's sending rate. | Agent Client sends the "Connect Info" to Server for on-line notification. Server would send "Get Capability" to get capability of this agent device and "Change AdvHeartBeat rate" to sync with System's sending rate. | ||
[[File:AdvHeartBeat-FC-6.jpg|800x400px|Agent Connect Info]] | [[File:AdvHeartBeat-FC-6.jpg|800x400px|Agent Connect Info]] | ||
− | + | ||
− | Type: Info | + | Description: gent Client sends the "Connect Info" to Server for on-line notification. |
− | Direction: Agent -> Server | + | Type: Info |
− | Topic: /cagent/admin/<devID>/agentinfoack | + | Direction: Agent -> Server |
− | QoS: 2 | + | Topic: /cagent/admin/<devID>/agentinfoack |
− | Retained: 0 | + | QoS: 2 |
− | Payload: | + | Retained: 0 |
− | { | + | Payload: |
+ | { | ||
+ | "susiCommData": { | ||
+ | "devID":"0017000E40000001", | ||
+ | "hostname":"AAA", | ||
+ | "sn":"0017000E40000001", | ||
+ | "mac":"0017000E40000001", | ||
+ | "version":"3.1.23", | ||
+ | "type":"SenHub", | ||
+ | "product":"WISE-1020", | ||
+ | "manufacture":"", | ||
+ | "status":"1", | ||
+ | "commCmd":1, | ||
+ | "requestID":30002, | ||
+ | "agentID":"0017000E40000001", | ||
+ | "handlerName":"general", | ||
+ | "sendTS":160081026 | ||
+ | } | ||
+ | } | ||
+ | |||
+ | ==<span style="color:#0070c0;">Get Capability</span>== | ||
+ | Server will send a "Get Capability" message to Agent after receiving a "Connect Info" message.<br /> | ||
+ | Agent will send back below messages when receiving a "Get Capability" message. | ||
+ | #OS Info | ||
+ | #All handler's capability ( ex: HWM, KVM, HDD, IoTGW...) | ||
+ | #All SenHub's "Connect Info" message. ( Send by IoTGWHandler ) | ||
+ | #Update the latest data of IoTGW ( Update by IoTGWHandler ) | ||
+ | |||
+ | [[File:AdvHeartBeat-FC-3.jpg|500x600px|Get Agent's Capability]] | ||
+ | |||
+ | Description: Server will send a "Get Capability" message to Agent after receiving a "Connect Info" message | ||
+ | Type: Request | ||
+ | Direction: Server -> Agent | ||
+ | Topic: /cagent/admin/<agentID>/agentcallbackreq | ||
+ | QoS: 0 | ||
+ | Retained: 0 | ||
+ | Payload: | ||
+ | { | ||
+ | "susiCommData": { | ||
+ | "requestID":1001, | ||
+ | "catalogID": 4, | ||
+ | "commCmd":2051, | ||
+ | "handlerName":"general" | ||
+ | } | ||
+ | } | ||
+ | |||
+ | Description: Agent will send back OS Info to Server after receiving "Get Capability" message. | ||
+ | Note: This feature will be implemented in version 3.2. | ||
+ | Type: Response | ||
+ | Direction: Agent -> Server | ||
+ | Topic: /cagent/admin/<devID>/agentactionreq | ||
+ | QoS: 0 | ||
+ | Retained: 0 | ||
+ | Payload: | ||
+ | { | ||
+ | "susiCommData":{ | ||
+ | "osInfo": { | ||
+ | "cagentVersion":"3.1.23", | ||
+ | "cagentType":"IoTGW", | ||
+ | "osVersion":"SnailOS", | ||
+ | "biosVersion":"", | ||
+ | "platformName":"", | ||
+ | "processorName":"SnailGW", | ||
+ | "osArch":"SnailX86", | ||
+ | "totalPhysMemKB":123, | ||
+ | "macs":"000E40ABCDEF", | ||
+ | "IP":"192.168.0.100" | ||
+ | }, | ||
+ | "commCmd":116, | ||
+ | "requestID":109, | ||
+ | "agentID":"0000000E40ABCDEF", | ||
+ | "handlerName":"general", | ||
+ | "sendTS":1466730390 | ||
+ | } | ||
+ | } | ||
+ | |||
+ | Description: Agent will send all handlers' capability to server. | ||
+ | Type: Response | ||
+ | Direction: Agent -> Server | ||
+ | Topic: /cagent/admin/<agentID>/agentactionreq | ||
+ | QoS: 0 | ||
+ | Retained: 0 | ||
+ | Payload: ( ex: HWM ) | ||
+ | { | ||
+ | "susiCommData": { | ||
+ | "infoSpec": { | ||
+ | "HWM": { | ||
+ | "e": [ | ||
+ | {"n": "v01","type": "volt","u": "V","max": 20,"min": 10}, | ||
+ | {"n": "v02","type": "volt","u": "V","max": 20,"min": 10}, | ||
+ | {"n": "t01","type": "temp","u": "Cel","max": 100,"min": 10}, | ||
+ | {"n": "V143360","type": "current","u": "A","max": 100,"min": 10} | ||
+ | ], | ||
+ | "bn": "HWM" | ||
+ | }, | ||
+ | "requestID": 2001, | ||
+ | "commCmd": 2052, | ||
+ | "catalogID": 4, | ||
+ | "agentID": "000014DAE996BE04", | ||
+ | "sendTS": 1417000000004, | ||
+ | "handlerName": "general" | ||
+ | } | ||
+ | } | ||
+ | } | ||
+ | |||
+ | Description: IoTGW Handler will update latest value of IoTGW. | ||
+ | Type: Response | ||
+ | Direction: Agent -> Server | ||
+ | Topic: /cagent/admin/<devID>/deviceinfo | ||
+ | QoS: 0 | ||
+ | Retained: 0 | ||
+ | Payload: | ||
+ | { | ||
+ | "susiCommData":{ | ||
+ | "data": { | ||
+ | "IoTGW": { | ||
+ | "WSN": { | ||
+ | "WSN0": { | ||
+ | "Info":{ | ||
+ | "e":[ | ||
+ | {"n":"SenHubList","sv":"0017000E40000000,0017000E40000001"}, | ||
+ | {"n":"Neighbor","sv":"0017000E40000000,0017000E40000001"}, | ||
+ | {"n":"Name","sv":"WSN0"}, | ||
+ | {"n":"Health","v":"100.000000"}, | ||
+ | {"n":"sw","sv":"1.2.1.12"}, | ||
+ | {"n":"reset","bv":"0"} | ||
+ | ], | ||
+ | "bn":"Info" | ||
+ | }, | ||
+ | "bn":"0007000E40ABCDEF", | ||
+ | "ver":1 | ||
+ | }, | ||
+ | "bn":"WSN" | ||
+ | }, | ||
+ | "ver":1 | ||
+ | } | ||
+ | }, | ||
+ | "commCmd":2055, | ||
+ | "requestID":2001, | ||
+ | "agentID":"0000000E40ABCDEF", | ||
+ | "handlerName":"general", | ||
+ | "sendTS":160081025 | ||
+ | } | ||
+ | } | ||
+ | |||
+ | Description: IoTGW Handler will send "Connect Info" for all "SenHub" devices. | ||
+ | Type: Response | ||
+ | Direction: Agent -> Server | ||
+ | Topic: /cagent/admin/<devID>/agentinfoack | ||
+ | QoS: 0 | ||
+ | Retained: 0 | ||
+ | Payload: | ||
+ | { | ||
"susiCommData": { | "susiCommData": { | ||
"devID":"0017000E40000001", | "devID":"0017000E40000001", | ||
Line 111: | Line 252: | ||
"sendTS":160081026 | "sendTS":160081026 | ||
} | } | ||
− | } | + | } |
− | |||
− | == | + | =Parameters of "AdvHeartBeat Protocol"= |
+ | ==<span style="color:#0070c0;">Sending Rate</span>== | ||
+ | Unit: second | ||
+ | Default: 60 | ||
+ | Range: 1 ~ 0xFFFFFFFF | ||
+ | -1 => Agent doesn't send "AdvHeartBeat" message | ||
− | + | ==<span style="color:#0070c0;">Query parameters of "AdvHeartBeat"</span>== | |
+ | [[File:AdvHeartBeat-FC-4.jpg|500x400px|Query parameters of "AdvHeartBeat"]] | ||
− | + | Type: Request | |
− | + | Direction: Server -> Agent | |
− | + | Topic: /cagent/admin/<devID>/agentcallbackreq | |
− | + | Payload: | |
+ | { | ||
+ | "susiCommData": { | ||
+ | "commCmd": 127, | ||
+ | "handlerName": "general", | ||
+ | "sessionID": "123465" | ||
+ | } | ||
+ | } | ||
− | + | Type: Response | |
− | + | Direction: Agent -> Server | |
− | Type: | + | Topic: /cagent/admin/<devID>/agentactionreq |
− | Direction: | + | Payload: |
− | Topic: /cagent/admin/< | + | { |
− | |||
− | |||
− | Payload: | ||
− | { | ||
"susiCommData": { | "susiCommData": { | ||
− | + | "commCmd": 128, | |
− | + | "handlerName": "general", | |
− | + | "heartbeatrate": 60, | |
− | + | "sessionID": "123465" | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
} | } | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
} | } | ||
− | </ | + | |
− | + | ==<span style="color:#0070c0;">Change parameters of "AdvHeartBeat"</span>== | |
− | Type: | + | [[File:AdvHeartBeat-FC-5.jpg|500x480px|Set parameter of "AdvHeartBeat"]] |
− | Direction: | + | |
− | Topic: /cagent/admin/<devID>/ | + | Type: Request |
− | + | Direction: Server -> Agent | |
− | + | Topic: /cagent/admin/<devID>/agentcallbackreq | |
− | Payload: | + | Payload: |
− | { | + | { |
− | + | "susiCommData": { | |
− | + | "commCmd": 129, | |
− | + | "handlerName": "general", | |
− | + | "heartbeatrate": 20, | |
− | + | "sessionID": "123465" | |
− | + | } | |
− | + | } | |
− | + | ||
− | + | Type: Response | |
− | + | Direction: Agent -> Server | |
− | + | Topic: /cagent/admin/<devID>/agentactionreq | |
− | + | Payload: | |
− | + | { | |
− | + | "susiCommData": { | |
− | + | "commCmd": 130, | |
− | + | "handlerName": "general", | |
− | + | "result":"SUCCESS", //or "FALSE" | |
− | + | "sessionID": "123465" | |
− | + | } | |
− | " | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | " | ||
− | |||
− | |||
− | |||
} | } | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | = Parameters of "AdvHeartBeat Protocol" = | + | =How to confirm the Agent supports "AdvHeartBeat" protocol?= |
+ | 1. Check the version in deviceinfo | ||
+ | Agent will support "AdvHeartBeat" in version "3.2". | ||
+ | >= 3.2 : Agent supports AdvHeartBeat | ||
+ | < 3.2 : Agent doesn't support AdvHeartBeat | ||
+ | |||
+ | 2. Query the parameters of "AdvHeartBeat" by "Query parameters of "AdvHeartBeat" | ||
+ | |||
+ | =Test Case= | ||
+ | ==Overview of Testing== | ||
+ | [[File:ConnectionReliability Testing Env.jpg|800x600px|Overview of Testing]] | ||
+ | ==<span style="color:#0070c0;">Expect</span>== | ||
+ | #Server/Client need follow specification to implement "AdvHeartBeat Protocol". | ||
+ | #Agent connection status on RMM Server must be correct in stable state. | ||
+ | #AdvHeartBeat can fix "lost connect info message issue". This issue maybe introduce by running order or dropping message by broker or RMM Server. | ||
+ | #AdvHeatBeat can fix "lost disconnect or will" message issue. | ||
+ | |||
+ | ==<span style="color:#0070c0;">Server Site - Check by Self</span>== | ||
+ | #Find all devices that its update time is over timeout from "AdvHeartBeat Table" & Check these devices is existing in "Device Table" | ||
+ | ##Yes -> If connection status is "On-line" change to "Off-line" | ||
+ | ##No -> Do Nothing | ||
+ | #Find all devices that its update time is not over timeout from "AdvHeartBeat Table" & Check these devices is existing in "Device Table" | ||
+ | ##Yes -> If connection status is "Off-line" -> Send a "Re-Connect" message to this device | ||
+ | ##No -> Send a "Re-Connect" message to this device | ||
+ | #Server can't misjudge earlier agent without "AdvHeartBeat"'s connection status to offline. | ||
+ | #Server needs take care the network and cpu loading to induce misjudge. ( The frequency of drop "AdvHeartBeat Message" is too high or tolerance is too lower ). | ||
+ | |||
+ | ==<span style="color:#0070c0;">Client Site - Check by Self</span>== | ||
+ | #Agent's OS version must greater "3.2.5" | ||
+ | #Agent sends "AdvHeartBeat Message" to Server in period | ||
+ | #Agent sends "AdvHeartBeat Parameters" after receiving a "Query Parameter of AdvHeartBeat Message". | ||
+ | #Agent will change and reply its "AdvHeartBeat Parameters" after receiving a "Setting AdvHeartBeat Message". | ||
+ | #Agent sends "Connect Info Message" to Server after receiving a "Re-Connect Message". | ||
+ | #Agent sends "OS Info", "Info Spec of all handler", "update values of IoTGW", and "Connect Info of all SenHub" while receiving a "Re-Connect Message". | ||
+ | |||
+ | ==<span style="color:#0070c0;">Integration Test</span>== | ||
+ | *RMM Server supports "AdvHeartBeat Protocol" | ||
+ | *Agent without "AdvHeartBeat" | ||
+ | *Agent with "AdvHeartBeat" | ||
+ | ===<span style="color:#0070c0;">Test by Node-Red</span>=== | ||
+ | #Lost first "Connect Info Msg" | ||
+ | #Lost "Disconnect Msg" and "Will Msg" | ||
+ | #Continue lost 1~5 "AdvHeartBeat Message" | ||
+ | ===<span style="color:#0070c0;">Network Environment</span>=== | ||
+ | #Unplug network cable 5 sec then plug-in. | ||
+ | #Up-plug network cable 3 mins then plug-in. | ||
+ | |||
+ | ===<span style="color:#0070c0;">Test by Manual</span>=== | ||
+ | #Broker and Agent client are started before RMM Server. | ||
+ | #RMM Server restart | ||
+ | |||
+ | ==<span style="color:#0070c0;">Node-Red for Test Case</span>== | ||
+ | [[Media:SendDisconnectMsg.txt|Send Disconnect Msg]]<br /> | ||
+ | |||
+ | [[Media:HB DropMsg.txt|Drop Connect / Disconnect / AdvHeartBeat Msg]]<br /> | ||
+ | |||
+ | [[Media:HB CheckVersion.txt|Check version of Agent]]<br /> | ||
+ | |||
+ | [[Media:HB CheckPeriod.txt|Check period of AdvHeartBeat rate]]<br /> | ||
+ | |||
+ | [[Media:HB Get Set Param Re-Connect Get Capability.txt|Get / Set AdvHeartBeat Params Get Capability, Re-Connect]]<br /> | ||
− | == | + | ==<span style="color:#0070c0;">Test Result</span>== |
− | < | + | [[Media:Connection Reliability v1 Test Result20160801.xlsx|V1 Test Result 20160801 Excel]]<br /> |
− | |||
− | |||
− | |||
− | </ | ||
− | + | [[File:ConnectionReliability v1 Test result.jpg|800x600px|Test result of v1]] |
Revision as of 10:58, 29 November 2016
Contents
AdvHeartBeat Protocol
AdvHeartBeat Topic & Payload
Type: Response Direction: Agent -> Server Topic: /cagent/admin/<devID>/notify QoS: 0 Retained: 0 Payload: ~ 35 character {"hb":{"devID":"0017000E40000001"}}
Client Site
- Agent needs send "AdvHeartBeat" message ( refer to AdvHeartBeat Topic & Payload ) by period as below picture.
Server Site
- Server would send "Get Capability" and "Change AdvHeartBeat sending rate" after receiving a "Connect Info" message.
- Server updates latest update time after receiving a AdvHeartBeat message with its AdvHeartBeat Table( NoSQL ).
- Server checks update time of AdvHeartBeat Table only.
- If the latest update time is over timeout ( Note: This value is depend on Server. Recommend: 3 x send rate => 3 x 60 = 180 sec => tolerate drop 2 AdvHeartBeat MSG ).
- If ( timeout & status is connected ) => changes status to disconnect & send a "Re-Connect" message to this device
- If there is latest AdvHeartBeat message in "AdvHeartBeat Table" but there is not device information in device list table ( SQL ).
- Server sends a re-connect message to this device.
Re-Connect Message
- If Server aware any problem of a device's status/information. Server will send a "Re-Connect" Message to Agent. Agent will send a "Connect Info" to Server after receiving a re-connect message. You can refer below for detail.
Description: Server sends "Re-Connect" message for asking agent re-send its "Connect Info". Type: Request Direction: Server -> Agent Topic: /cagent/admin/<devID>/agentcallbackreq QoS: 0 Retained: 0 Payload: { "susiCommData": { "commCmd": 125, "handlerName": "general", "response": { "statuscode": 4, "msg": "Reconnect" } } }
Description: Agent will send "Connect Info" after receiving a "Re-Connect" message. Type: Response Direction: Agent -> Server Topic: /cagent/admin/<devID>/agentinfoack QoS: 2 Retained: 0 Payload: { "susiCommData": { "devID":"0017000E40000001", "hostname":"AAA", "sn":"0017000E40000001", "mac":"0017000E40000001", "version":"3.1.23", "type":"SenHub", "product":"WISE-1020", "manufacture":"", "status":"1", "commCmd":1, "requestID":30002, "agentID":"0017000E40000001", "handlerName":"general", "sendTS":160081026 } }
Connect Info
Agent Client sends the "Connect Info" to Server for on-line notification. Server would send "Get Capability" to get capability of this agent device and "Change AdvHeartBeat rate" to sync with System's sending rate.
Description: gent Client sends the "Connect Info" to Server for on-line notification. Type: Info Direction: Agent -> Server Topic: /cagent/admin/<devID>/agentinfoack QoS: 2 Retained: 0 Payload: { "susiCommData": { "devID":"0017000E40000001", "hostname":"AAA", "sn":"0017000E40000001", "mac":"0017000E40000001", "version":"3.1.23", "type":"SenHub", "product":"WISE-1020", "manufacture":"", "status":"1", "commCmd":1, "requestID":30002, "agentID":"0017000E40000001", "handlerName":"general", "sendTS":160081026 } }
Get Capability
Server will send a "Get Capability" message to Agent after receiving a "Connect Info" message.
Agent will send back below messages when receiving a "Get Capability" message.
- OS Info
- All handler's capability ( ex: HWM, KVM, HDD, IoTGW...)
- All SenHub's "Connect Info" message. ( Send by IoTGWHandler )
- Update the latest data of IoTGW ( Update by IoTGWHandler )
Description: Server will send a "Get Capability" message to Agent after receiving a "Connect Info" message Type: Request Direction: Server -> Agent Topic: /cagent/admin/<agentID>/agentcallbackreq QoS: 0 Retained: 0 Payload: { "susiCommData": { "requestID":1001, "catalogID": 4, "commCmd":2051, "handlerName":"general" } }
Description: Agent will send back OS Info to Server after receiving "Get Capability" message. Note: This feature will be implemented in version 3.2. Type: Response Direction: Agent -> Server Topic: /cagent/admin/<devID>/agentactionreq QoS: 0 Retained: 0 Payload: { "susiCommData":{ "osInfo": { "cagentVersion":"3.1.23", "cagentType":"IoTGW", "osVersion":"SnailOS", "biosVersion":"", "platformName":"", "processorName":"SnailGW", "osArch":"SnailX86", "totalPhysMemKB":123, "macs":"000E40ABCDEF", "IP":"192.168.0.100" }, "commCmd":116, "requestID":109, "agentID":"0000000E40ABCDEF", "handlerName":"general", "sendTS":1466730390 } }
Description: Agent will send all handlers' capability to server. Type: Response Direction: Agent -> Server Topic: /cagent/admin/<agentID>/agentactionreq QoS: 0 Retained: 0 Payload: ( ex: HWM ) { "susiCommData": { "infoSpec": { "HWM": { "e": [ {"n": "v01","type": "volt","u": "V","max": 20,"min": 10}, {"n": "v02","type": "volt","u": "V","max": 20,"min": 10}, {"n": "t01","type": "temp","u": "Cel","max": 100,"min": 10}, {"n": "V143360","type": "current","u": "A","max": 100,"min": 10} ], "bn": "HWM" }, "requestID": 2001, "commCmd": 2052, "catalogID": 4, "agentID": "000014DAE996BE04", "sendTS": 1417000000004, "handlerName": "general" } } }
Description: IoTGW Handler will update latest value of IoTGW. Type: Response Direction: Agent -> Server Topic: /cagent/admin/<devID>/deviceinfo QoS: 0 Retained: 0 Payload: { "susiCommData":{ "data": { "IoTGW": { "WSN": { "WSN0": { "Info":{ "e":[ {"n":"SenHubList","sv":"0017000E40000000,0017000E40000001"}, {"n":"Neighbor","sv":"0017000E40000000,0017000E40000001"}, {"n":"Name","sv":"WSN0"}, {"n":"Health","v":"100.000000"}, {"n":"sw","sv":"1.2.1.12"}, {"n":"reset","bv":"0"} ], "bn":"Info" }, "bn":"0007000E40ABCDEF", "ver":1 }, "bn":"WSN" }, "ver":1 } }, "commCmd":2055, "requestID":2001, "agentID":"0000000E40ABCDEF", "handlerName":"general", "sendTS":160081025 } }
Description: IoTGW Handler will send "Connect Info" for all "SenHub" devices. Type: Response Direction: Agent -> Server Topic: /cagent/admin/<devID>/agentinfoack QoS: 0 Retained: 0 Payload: { "susiCommData": { "devID":"0017000E40000001", "hostname":"AAA", "sn":"0017000E40000001", "mac":"0017000E40000001", "version":"3.1.23", "type":"SenHub", "product":"WISE-1020", "manufacture":"", "status":"1", "commCmd":1, "requestID":30002, "agentID":"0017000E40000001", "handlerName":"general", "sendTS":160081026 } }
Parameters of "AdvHeartBeat Protocol"
Sending Rate
Unit: second Default: 60 Range: 1 ~ 0xFFFFFFFF -1 => Agent doesn't send "AdvHeartBeat" message
Query parameters of "AdvHeartBeat"
Type: Request Direction: Server -> Agent Topic: /cagent/admin/<devID>/agentcallbackreq Payload: { "susiCommData": { "commCmd": 127, "handlerName": "general", "sessionID": "123465" } }
Type: Response Direction: Agent -> Server Topic: /cagent/admin/<devID>/agentactionreq Payload: { "susiCommData": { "commCmd": 128, "handlerName": "general", "heartbeatrate": 60, "sessionID": "123465" } }
Change parameters of "AdvHeartBeat"
Type: Request Direction: Server -> Agent Topic: /cagent/admin/<devID>/agentcallbackreq Payload: { "susiCommData": { "commCmd": 129, "handlerName": "general", "heartbeatrate": 20, "sessionID": "123465" } }
Type: Response Direction: Agent -> Server Topic: /cagent/admin/<devID>/agentactionreq Payload: { "susiCommData": { "commCmd": 130, "handlerName": "general", "result":"SUCCESS", //or "FALSE" "sessionID": "123465" } }
How to confirm the Agent supports "AdvHeartBeat" protocol?
1. Check the version in deviceinfo
Agent will support "AdvHeartBeat" in version "3.2". >= 3.2 : Agent supports AdvHeartBeat < 3.2 : Agent doesn't support AdvHeartBeat
2. Query the parameters of "AdvHeartBeat" by "Query parameters of "AdvHeartBeat"
Test Case
Overview of Testing
Expect
- Server/Client need follow specification to implement "AdvHeartBeat Protocol".
- Agent connection status on RMM Server must be correct in stable state.
- AdvHeartBeat can fix "lost connect info message issue". This issue maybe introduce by running order or dropping message by broker or RMM Server.
- AdvHeatBeat can fix "lost disconnect or will" message issue.
Server Site - Check by Self
- Find all devices that its update time is over timeout from "AdvHeartBeat Table" & Check these devices is existing in "Device Table"
- Yes -> If connection status is "On-line" change to "Off-line"
- No -> Do Nothing
- Find all devices that its update time is not over timeout from "AdvHeartBeat Table" & Check these devices is existing in "Device Table"
- Yes -> If connection status is "Off-line" -> Send a "Re-Connect" message to this device
- No -> Send a "Re-Connect" message to this device
- Server can't misjudge earlier agent without "AdvHeartBeat"'s connection status to offline.
- Server needs take care the network and cpu loading to induce misjudge. ( The frequency of drop "AdvHeartBeat Message" is too high or tolerance is too lower ).
Client Site - Check by Self
- Agent's OS version must greater "3.2.5"
- Agent sends "AdvHeartBeat Message" to Server in period
- Agent sends "AdvHeartBeat Parameters" after receiving a "Query Parameter of AdvHeartBeat Message".
- Agent will change and reply its "AdvHeartBeat Parameters" after receiving a "Setting AdvHeartBeat Message".
- Agent sends "Connect Info Message" to Server after receiving a "Re-Connect Message".
- Agent sends "OS Info", "Info Spec of all handler", "update values of IoTGW", and "Connect Info of all SenHub" while receiving a "Re-Connect Message".
Integration Test
- RMM Server supports "AdvHeartBeat Protocol"
- Agent without "AdvHeartBeat"
- Agent with "AdvHeartBeat"
Test by Node-Red
- Lost first "Connect Info Msg"
- Lost "Disconnect Msg" and "Will Msg"
- Continue lost 1~5 "AdvHeartBeat Message"
Network Environment
- Unplug network cable 5 sec then plug-in.
- Up-plug network cable 3 mins then plug-in.
Test by Manual
- Broker and Agent client are started before RMM Server.
- RMM Server restart
Node-Red for Test Case
Drop Connect / Disconnect / AdvHeartBeat Msg
Check period of AdvHeartBeat rate
Get / Set AdvHeartBeat Params Get Capability, Re-Connect