Difference between revisions of "Connectivity/AdvHeartBeat"
From ESS-WIKI
(→Query parameters of "AdvHeartBeat") |
Eric.liang (talk | contribs) |
||
| (58 intermediate revisions by 2 users not shown) | |||
| Line 1: | Line 1: | ||
=AdvHeartBeat Protocol= | =AdvHeartBeat Protocol= | ||
| − | ==AdvHeartBeat Topic & Payload== | + | ==<span style="color:#0070c0;">AdvHeartBeat Topic & Payload</span>== |
Type: Response | Type: Response | ||
Direction: Agent -> Server | Direction: Agent -> Server | ||
| Line 9: | Line 9: | ||
{"hb":{"devID":"0017000E40000001"}} | {"hb":{"devID":"0017000E40000001"}} | ||
| − | ==Client Site== | + | ==<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 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 ). | ||
| − | #Server | + | #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 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 | + | ##If ( timeout & status is connected ) => changes status to disconnect & send a "Re-Connect" message to this device |
| − | #If | + | #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. | ##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 | + | :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]] | ||
| − | Description: Server | + | Description: Server sends "Re-Connect" message for asking agent re-send its "Connect Info". |
Type: Request | Type: Request | ||
Direction: Server -> Agent | Direction: Server -> Agent | ||
| Line 46: | Line 46: | ||
} | } | ||
| − | Description: Agent will send | + | Description: Agent will send "Connect Info" after receiving a "Re-Connect" message. |
Type: Response | Type: Response | ||
Direction: Agent -> Server | Direction: Agent -> Server | ||
Topic: /cagent/admin/<devID>/agentinfoack | Topic: /cagent/admin/<devID>/agentinfoack | ||
| − | QoS: 0 | + | 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 | ||
| + | } | ||
| + | } | ||
| + | |||
| + | == <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. | ||
| + | |||
| + | [[File:AdvHeartBeat-FC-6.jpg|800x400px|Agent Connect Info]] | ||
| + | |||
| + | Description: Agent 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 | Retained: 0 | ||
Payload: | Payload: | ||
| Line 72: | Line 104: | ||
} | } | ||
| − | ==Get Capability== | + | ==<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]] | [[File:AdvHeartBeat-FC-3.jpg|500x600px|Get Agent's Capability]] | ||
| − | Description: Server | + | Description: Server will send a "Get Capability" message to Agent after receiving a "Connect Info" message |
Type: Request | Type: Request | ||
Direction: Server -> Agent | Direction: Server -> Agent | ||
| Line 121: | Line 159: | ||
} | } | ||
} | } | ||
| − | + | ||
| − | Description: Agent will send | + | Description: Agent will send all handlers' capability to server. |
Type: Response | Type: Response | ||
Direction: Agent -> Server | Direction: Agent -> Server | ||
| Line 150: | Line 188: | ||
} | } | ||
} | } | ||
| + | |||
| + | 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"= | =Parameters of "AdvHeartBeat Protocol"= | ||
| − | ==Sending Rate== | + | ==<span style="color:#0070c0;">Sending Rate</span>== |
Unit: second | Unit: second | ||
Default: 60 | Default: 60 | ||
| Line 158: | Line 262: | ||
-1 => Agent doesn't send "AdvHeartBeat" message | -1 => Agent doesn't send "AdvHeartBeat" message | ||
| − | ==Query parameters of "AdvHeartBeat"== | + | ==<span style="color:#0070c0;">Query parameters of "AdvHeartBeat"</span>== |
[[File:AdvHeartBeat-FC-4.jpg|500x400px|Query parameters of "AdvHeartBeat"]] | [[File:AdvHeartBeat-FC-4.jpg|500x400px|Query parameters of "AdvHeartBeat"]] | ||
| Line 186: | Line 290: | ||
} | } | ||
| − | ==Change parameters of "AdvHeartBeat"== | + | ==<span style="color:#0070c0;">Change parameters of "AdvHeartBeat"</span>== |
| + | [[File:AdvHeartBeat-FC-5.jpg|500x480px|Set parameter of "AdvHeartBeat"]] | ||
Type: Request | Type: Request | ||
Direction: Server -> Agent | Direction: Server -> Agent | ||
| − | Topic: /cagent/admin/<devID>/agentcallbackreq | + | Topic: /cagent/admin/<devID>/agentcallbackreq |
Payload: | Payload: | ||
{ | { | ||
| Line 221: | Line 326: | ||
2. Query the parameters of "AdvHeartBeat" by "Query parameters of "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]] | ||
Latest revision as of 02:25, 20 February 2017
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: Agent 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