在使用java的socket发送数据的时候出现了问题,问题描述如下:
在调用socket的write方法的时候线程被无限期的阻塞。
初步排查推测可能是tcp连接的发送缓冲区被填满,导致write方法无限期阻塞,于是采用以下方案:将单链接改为多连接,从而为每个连接分配一个缓冲区,进而避免发送缓冲区被填满的情况。然而以上问题依然没有解决,我推测可能是对方的接收缓冲区被填满,然后其连接的处理程序可能被无限期阻塞,从而导致接收缓冲区一直处于被填满的状态,进而导致我的发送缓冲区也一直保持被填满的状态,最终表现为调用write方法的线程被无限期阻塞。于是采用以下方案:
使用future类实现阻塞超时,当write方法的阻塞时间超过5s时会自动断开连接,如此线程无限期阻塞的问题被解决,然而对方依然无法接收到数据。使用tcpdump查看发现而我这边一直在发送ack,对方返回的滑动窗口一直为0,要解决问题的根本方法是当对方的滑动窗口为0时,我这边主动断开连接,然而根据以上情况来看无法通过write方法的阻塞时间来判断对方的滑动窗口是否为0,必须找到另一种方法判断对方的滑动窗口为0,即对方的接收缓存区一直处于被填满的状态