MQTT异常断开

本文详细探讨了MQTT连接在遇到TCP网络问题时的四种常见异常断开情况:心跳超时、网络拥塞重传、ACK确认丢失和网络不稳定。通过实例分析,揭示了这些问题如何影响客户端与Broker之间的通信,并提供了网络优化建议。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MQTT异常断开,讨论一下TCP链路的影响

MQTT异常断开,TCP链路原因的几种情况:

三种情况:

1、客户端发送了心跳请求,但是MQTT代理服务器Broker没有收到心跳请求,所以也不会回复客户端心跳响应。MQTT代理服务器Broker在 1.5T 心跳周期内没有收到心跳请求,主动断开MQTT连接。

        后续分析,怪异的现象是:发送端 send() 接口发送成功(注意:send接口返回值是正确的),客户端在发送时遇到了网络信号故障,send()接口发送数据交给系统之后就不关心了。这个在物联网中还是有概率发生的,是网络信号不稳定(往往是网络信号强度不够)导致的,与下面的一种TCP拥塞,情况还不太一样。

        这种信号差导致客户端的心跳请求发送失败,虽然概率比较低,但是MQTT应用在网络延时比较大,网络信号较差的环境中,所以还是有一定出现的次数。

2、客户端发送了MQTT心跳请求,但是TCP网络的原因出现多次重传,客户端发给了MQTT代理服务器Broker,但是代理服务器的网络故障问题,没有及时处理客户端发来的心跳请求。代理服务器Broker设置MQTT心跳 1.5T 心跳周期没有收到心跳请求包,将踢掉MQTT连接。

        使用wireshark抓包工具,看到网络拥塞,代理服务器端的网络状态极差。

3、客户端给MQTT代理服务器发送TCP层的ACK确认包,代理服务器没有收到TCP层的ACK确认,然后客户端发起TCP层链路重置。注意是TCP层的链路重置[RST, ACK],或者是[FIN, ACK]。然后TCP层链路中断,MQTT连接随之中断。

        这种情况也是代理服务器Broker的网络较差,不能及时处理收到的MQTT消息在TCP层的ACK确认。

4、连接时网络不稳定,双向的,或者是单向的原因。下图中红色标注部分,分别是客户端与代理服务器Broker之间相互等待,但是等待的时间点却不一样,注意这里面的区分。

附一张图:

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值