C# 使用MQTTnet 4.1 Client通讯异常检测失效处理

C#下的MQTTnet是非常好用的开源组件,最近在使用时发现特殊情况下,client不能有效检测到网络的异常断开,排查过程如下:

环境:笔记本,Win10+VS2022+MQTTnet 4.1.4.563,运行客户端,MQTT服务器在云端,笔记本使用Wifi联网。

测试准备:编写客户端软件,使用客户端与服务端连接并定时发送数据

  1. 断开笔记本的Wifi

可以马上检测到与服务端断开,恢复网络后正常重连

  1. 断开Wifi热点

可以马上检测到与服务端断开,恢复网络后正常重连

  1. Wifi连接保持不动,断开Wifi热点的数据网络

客户端检测不到网络断开,发送数据返回成功。这时通过Windows的“任务管理器”->“性能”->"打开资源监视器"->"网络",观察进程对应的"网络活动"和"TCP连接",发现进程在继续发数据,TCP连接没有断开,估计的底层通讯有异常。

调整客户端连接的MqttQualityOfServiceLevel到ExactlyOnce,问题依旧

调整WithKeepAlivePeriod、WithTimeout,问题依旧

恢复Wifi数据网络,客户端没有检测网络断开与恢复,继续发送数据,云平台上的MQTT服务端显示客户端已经断开,没有重连。

  1. 解决办法

查看文档,MQTT Client支持Ping命名,定期调用mqttClient.PingAsync().Wait(),可以快速发现网络异常。使用try-catch,捕获异常为网络断开,进行相应处理即可。

MQTTnet开源地址:dotnet/MQTTnet

你可能感兴趣的:(编程,IoT,c#,MQTT,断开异常)