问题现象
在与第三方系统通过http交互数据的过程中,抓包发现每次TCP连接都是异常关闭,报文如下:
可以看到,由我方发起3次握手建立连接,然后发送http请求,对方响应数据,我方ACK后直接发RST包(图中蓝色阴影部分),将连接异常关闭,不仅没有复用连接,且不是通过4次挥手来关闭连接。
问题原因
HttpClient 4.5.2 释放连接API使用方式不正确
问题代码如下(已简化):
private boolean isCheckSuccess() {
CloseableHttpResponse response = null;
try {
// 通过HttpClientBuilder创建CloseableHttpClient
httpClient = HttpClientFactory.createHttpClient();
request = initCheckRequest();
response = httpClient.execute(request);
if(response.getStatusLine().getStatusCode() == HttpStatus.SC_OK) {
return true;
}
} finally {