遠程訪問連接,設置時間,從而減小沒必要要的麻煩,可是HttpClient版本不一致,方法不同,因此有了以下設置html
原帖連接:https://www.cnblogs.com/jimmy-muyuan/p/6012736.htmljava
場景:最近併發較高,看到響應時間6s的時候,內心咯噔一下,我記得我設置的超時時間是5s啊。apache
原來讀取超時時間沒生效,只生效了鏈接超時時間。服務器
ConnectionPoolTimeoutException 獲取鏈接池鏈接超時網絡
ConnectionTimeout:這定義了經過網絡與服務器創建鏈接的超時時間。Httpclient包中經過一個異步線程去建立與服務器的socket鏈接,這就是該socket鏈接的超時時間,此處設置爲3秒。併發
將url改成一個不存在的url,則會拋出org.apache.commons.httpclient.ConnectTimeoutException異步
SocketTimeout:這定義了Socket讀數據的超時時間,即從服務器獲取響應數據須要等待的時間,此處設置爲5秒。socket
請求的地址sleep5s後返回數據,則拋出:java.net.SocketTimeoutException: Read timed outui
這是個3.X的超時設置方法url
HttpClient client = new HttpClient();
client.setConnectionTimeout(30000);
client.setTimeout(30000);
HttpClient httpClient=
new
DefaultHttpClient();
httpClient.getParams().setParameter(CoreConnectionPNames.CONNECTION_TIMEOUT,
2000
);
//鏈接時間
httpClient.getParams().setParameter(CoreConnectionPNames.SO_TIMEOUT,
2000
);
//數據傳輸時間
4.3版本超時設置
CloseableHttpClient httpClient = HttpClients.createDefault();
HttpGet httpGet=new HttpGet("http://www.baidu.com");//HTTP Get請求
RequestConfig requestConfig = RequestConfig.custom().setSocketTimeout(2000).setConnectTimeout(2000).build();//設置請求和傳輸超時時間
httpGet.setConfig(requestConfig);
httpClient.execute(httpGet);//執行請求
之後再寫httpClient這兩個超時時間必定要加上,不加就極可能悲劇的了