HttpClient超時設置


場景:最近並發較高,看到響應時間6s的時候,心里咯噔一下,我記得我設置的超時時間是5s啊。

 

原來讀取超時時間沒生效,只生效了連接超時時間。

ConnectionPoolTimeoutException 獲取連接池連接超時

ConnectionTimeout:這定義了通過網絡與服務器建立連接的超時時間。Httpclient包中通過一個異步線程去創建與服務器的socket連接,這就是該socket連接的超時時間,此處設置為3秒。

將url改為一個不存在的url,則會拋出org.apache.commons.httpclient.ConnectTimeoutException

SocketTimeout:這定義了Socket讀數據的超時時間,即從服務器獲取響應數據需要等待的時間,此處設置為5秒。

請求的地址sleep5s后返回數據,則拋出:java.net.SocketTimeoutException: Read timed out

 

 

這是個3.X的超時設置方法

HttpClient client = new HttpClient();

client.setConnectionTimeout(30000);

client.setTimeout(30000);

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這兩個超時時間一定要加上,不加就很可能悲劇的了


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM