標籤:stc creat 非同步 tom span .net nbsp conf comm
情境:最近並發較高,看到回應時間6s的時候,心裡咯噔一下,我記得我設定的逾時時間是5s啊。
原來讀取逾時時間沒生效,只生效了連線逾時時間。
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這兩個逾時時間一定要加上,不加就很可能悲劇的了
HttpClient逾時設定