环境为安卓手机用socket连接linux里的python服务器。
这种跨语言的东西,客户端和服务器端建立链接之后,其中一方发生断网、物理死机等等原因导致socket异常断开,是只有自己知道的,对面的人是不知道你已经断掉,因为你这边根本没有发出请求要求断开。
调试bug的情况是:
1.python服务器物理断开(断网,没电等),但安卓客户端认为socket仍在链接,且会不断收到空字节包,不做处理会导致卡死。
2.安卓客户端物理断开(断网,没电等)、各种调用close方法,但python服务器认为socket仍在链接,且会不断收到空字节包,不做处理会导致卡死。
3.python服务器与python客户端互相建立链接、断开均无异常问题。
总结1和2发现情形非常相似,初步怀疑是对TCP协议的三次握手建立和四次握手断开没有理解到位,不同语言对操作系统层面的设置各有不同,同语言下socket建立链接、断开想必是没有问题的,跨语言则需投入更多努力来防bug。
解决办法:
服务器定时发送自定义心跳包,客户端收到包立即回应,服务器发送失败会报异常,此时断开无问题,服务器若超时未收到回应,则走流程断开亦无问题。同时,客户端只要收到包立即发送回应,发送失败也会报异常,此时close断开无问题。
更多参考:
TCP协议中的三次握手和四次挥手https://blog.csdn.net/whuslei/article/details/6667471
客户端怎么判断Socket连接已与服务器断开https://blog.csdn.net/brk1985/article/details/38677289
版权声明:本文为IAmYourFarther原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。