問題定位:java
凡是系統中出現大量的CLOSE_WAIT,說明你的代碼寫的有問題,即:沒有關閉鏈接。spring
在OkHttpClient中,默認時 HTTP頭字段 Connection 設置值爲keep-alive,這樣會致使服務端斷開鏈接時,客戶端不能及時的斷開鏈接,從而出現大量的CLOSE_WAIT。json
問題修改:app
把HTTP頭字段 Connection 設置值爲closeide
以下是一段短鏈接http調用代碼。post
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
package com.xman.httpclient;ui
import okhttp3.*;
import org.springframework.stereotype.Service;url
import java.io.IOException;
import java.util.concurrent.TimeUnit;對象
/**utf-8
Created by wangyaofu on 2018/4/25.br/>*/
@Service
public class HttpServiceImpl {
public final static int CONNECT_TIMEOUT =10000;
public final static int READ_TIMEOUT=10000;
public final static int WRITE_TIMEOUT=10000;
public String httpGet(String url, String userAgent) {
final Request request = new Request.Builder()
.url(url).header("User-Agent", userAgent).header("Connection", "close")
.build();
OkHttpClient okHttpClient = new OkHttpClient.Builder()
.readTimeout(READ_TIMEOUT, TimeUnit.MILLISECONDS)
.writeTimeout(WRITE_TIMEOUT, TimeUnit.MILLISECONDS)
.connectTimeout(CONNECT_TIMEOUT, TimeUnit.MILLISECONDS)
.build();
Response response;
try {
response = okHttpClient.newCall(request).execute();
return response.body().string();
} catch (Exception e) {
//logger.error("httpGet err=" + e.getMessage());
}
return null;
}
public String httpPost(String url, String body) {RequestBody requestBody = RequestBody.create(MediaType.parse("application/json; charset=utf-8"), body);//建立一個請求對象Request request = new Request.Builder().url(url).header("Connection", "close").post(requestBody).build();//發送請求獲取響應try {OkHttpClient okHttpClient = new OkHttpClient.Builder().readTimeout(READ_TIMEOUT, TimeUnit.MILLISECONDS).writeTimeout(WRITE_TIMEOUT, TimeUnit.MILLISECONDS).connectTimeout(CONNECT_TIMEOUT, TimeUnit.MILLISECONDS).build();Response response=okHttpClient.newCall(request).execute();if (response != null && response.body() != null) {return response.body().string();}} catch (Exception e) {//logger.error("httpPost err=" + e.getMessage());}return null;}