C#下的MQTTnet是非常好用的开源组件,最近在使用时发现特殊情况下,client不能有效检测到网络的异常断开,排查过程如下:
环境:笔记本,Win10+VS2022+MQTTnet 4.1.4.563,运行客户端,MQTT服务器在云端,笔记本使用Wifi联网。
测试准备:编写客户端软件,使用客户端与服务端连接并定时发送数据
断开笔记本的Wifi
可以马上检测到与服务端断开,恢复网络后正常重连
断开Wifi热点
可以马上检测到与服务端断开,恢复网络后正常重连
Wifi连接保持不动,断开Wifi热点的数据网络
客户端检测不到网络断开,发送数据返回成功。这时通过Windows的“任务管理器”->“性能”->"打开资源监视器"->"网络",观察进程对应的"网络活动"和"TCP连接",发现进程在继续发数据,TCP连接没有断开,估计的底层通讯有异常。
调整客户端连接的MqttQualityOfServiceLevel到ExactlyOnce,问题依旧
调整WithKeepAlivePeriod、WithTimeout,问题依旧
恢复Wifi数据网络,客户端没有检测网络断开与恢复,继续发送数据,云平台上的MQTT服务端显示客户端已经断开,没有重连。
解决办法
查看文档,MQTT Client支持Ping命名,定期调用mqttClient.PingAsync().Wait(),可以快速发现网络异常。使用try-catch,捕获异常为网络断开,进行相应处理即可。
MQTTnet开源地址:dotnet/MQTTnet