千家信息网

【bug-004】【tcp】网络断开重连后,客户端recv函数一直阻塞,不会返回

发表于:2025-01-31 作者:千家信息网编辑
千家信息网最后更新 2025年01月31日,【前提】客户端采用tcp阻塞模式【现象】与相机设备建立连接后,偶尔出现几次突然就收不到相机发过来的数据;几经排查,怀疑跟网络波动有关,于是通过插拔网线来模拟网络波动,果然bug复现。【分析】为什么网络
千家信息网最后更新 2025年01月31日【bug-004】【tcp】网络断开重连后,客户端recv函数一直阻塞,不会返回

【前提】客户端采用tcp阻塞模式
【现象】与相机设备建立连接后,偶尔出现几次突然就收不到相机发过来的数据;几经排查,怀疑跟网络波动有关,于是通过插拔网线来模拟网络波动,果然bug复现。

【分析】为什么网络中断tcp不主动通知应用程序呢?这涉及到TPC/IP协议的一个设计原则,即终端对终端参数。什么意思呢?就是由调用层选择是否需要这种功能,如果需要,调用者就自己设置相应参数,而不是tcp一检测到网络中断就及时反馈,因为大多数的应用程序并不需要即时的通知。
ps:我们自己设计接口的时候也应该考虑这种原则。

【解决方案】
1、换成非阻塞模式;
2、阻塞+保活。
这样,就可以利用函数返回值来判断是否需要重连了。

0