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

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

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

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