如何区分Apache HttpClient中配置的三个超时时间。
1. 初始化HttpClient
先引入jar包,以gradle为例:
compile 'org.apache.httpcomponents:httpclient:4.5.6'
先看以下HttpClient的初始化代码:
public static CloseableHttpClient buildHttpClient(
int maxConnTotal,
int maxConnPerRoute,
int connectionRequestTimeout,
int connectTimeout,
int socketTimeout) {
RequestConfig requestConfig =
RequestConfig.custom()
// 从连接池中获取连接的超时时间
.setConnectionRequestTimeout(connectionRequestTimeout)
// 与服务器连接超时时间:httpclient会创建一个异步线程用以创建socket连接,此处设置该socket的连接超时时间
.setConnectTimeout(connectTimeout)
// socket读数据超时时间:从服务器获取响应数据的超时时间
.setSocketTimeout(socketTimeout)
.build();
CloseableHttpClient httpClient =
HttpClientBuilder.create()
// 连接池中最大连接数
.setMaxConnTotal(maxConnTotal)
/**
* 分配给同一个route(路由)最大的并发连接数。 route:运行环境机器 到 目标机器的一条线路。
* 举例来说,我们使用HttpClient的实现来分别请求 www.baidu.com 的资源和 www.bing.com
* 的资源那么他就会产生两个route。
*/
.setMaxConnPerRoute(maxConnPerRoute)
.setDefaultRequestConfig(requestConfig)
.build();
return httpClient;
}
2. 三个超时时间详解
2.1从连接池中获取可用连接超时
HttpClient中的要用连接时尝试从连接池中获取,若是在等待了一定的时间后还没有获取到可用连接(比如连接池中没有空闲连接了)则会抛出获取连接超时异常。
2.2 连接目标超时connectionTimeout
指的是连接目标url的连接超时时间,即客服端发送请求到与目标url建立起连接的最大时间。如果在该时间范围内还没有建立起连接,则就抛出connectionTimeOut异常。 如测试的时候,将url改为一个不存在的url:“http://test.com” , 超时时间3000ms过后,系统报出异常: org.apache.commons.httpclient.ConnectTimeoutException:The host did not accept the connection within timeout of 3000 ms
2.3 等待响应超时(读取数据超时)socketTimeout
连接上一个url后,获取response的返回等待时间 ,即在与目标url建立连接后,等待放回response的最大时间,在规定时间内没有返回响应的话就抛出SocketTimeout。
「真诚赞赏,手留余香」
请我喝杯咖啡?
使用微信扫描二维码完成支付
