java httpclient 阻塞_java – Httpclient 4.3阻塞连接池

本文讨论了在使用Java HttpClient 4.3时遇到的阻塞问题,特别是在连接池管理方面。通过分析代码和线程状态,发现问题是由于等待连接池分配连接导致的。要解决这个问题,可以考虑调整连接池配置,如增大最大连接数或超时设置。
摘要由CSDN通过智能技术生成

当我使用httpclient 4.3如下

static {

try {

SSLContextBuilder builder = new SSLContextBuilder();

builder.loadTrustMaterial(null, new TrustSelfSignedStrategy());

SSLConnectionSocketFactory sslsf = new SSLConnectionSocketFactory(builder.build());

CookieSpecProvider easySpecProvider = new CookieSpecProvider() {

public CookieSpec create(HttpContext context) {

return new BrowserCompatSpec() {

@Override

public void validate(Cookie cookie, CookieOrigin origin) throws MalformedCookieException {

// Oh, I am easy

}

};

}

};

Registry r = RegistryBuilder. create()

.register(CookieSpecs.BEST_MATCH, new BestMatchSpecFactory())

.register(CookieSpecs.BROWSER_COMPATIBILITY, new BrowserCompatSpecFactory())

.register("easy", easySpecProvider).build();

RequestConfig requestConfig = RequestConfig.custom().setConnectionRequestTimeout(5000)

.setSocketTimeout(10000).setConnectTimeout(10000).setCookieSpec("easy").setRedirectsEnabled(false)

.build();

PoolingHttpClientConnectionManager cm = new PoolingHttpClientConnectionManager();

cm.setMaxTotal(100);

cm.setDefaultMaxPerRoute(10);

client = HttpClients.custom().setConnectionManager(cm).setDefaultCookieSpecRegistry(r)

.setSSLSocketFactory(sslsf).setDefaultRequestConfig(requestConfig).build();

} catch (Exception e) {

logger.error("http client init fail!", e);

}

}

public static String execute(HttpRequest httpRequest) {

CloseableHttpResponse response = null;

HttpGet httpGet = null;

HttpEntity httpEntity = null;

try {

httpGet = new HttpGet(httpRequest.getUrl());

httpGet.setHeader("Connection", "close");

if (httpRequest.isUseGzip()) {

httpGet.addHeader("Accept-Encoding", "gzip,deflate,sdch");

}

if (!StringUtils.isEmpty(httpRequest.getContentType())) {

httpRequest.setContentType(httpRequest.getContentType());

}

httpGet.addHeader("User-Agent",

"Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63");

response = client.execute(httpGet);

httpEntity = response.getEntity();

byte[] bytes = null;

try {

bytes = EntityUtils.toByteArray(httpEntity);

} catch (Exception e) {

return null;

}

if (response.getStatusLine().getStatusCode() != 200) {

logger.warn("error! StatusCode: " + response.getStatusLine().getStatusCode() + ", url: "

+ httpRequest.getUrl());

return null;

}

@SuppressWarnings("deprecation")

String charset = EntityUtils.getContentCharSet(httpEntity);

if (StringUtils.isEmpty(charset)) {

Matcher match = charsetPatterm.matcher(new String(bytes));

if (match.find()) {

charset = match.group(1);

}

}

if (!StringUtils.isEmpty(charset)) {

String strUtf8 = new String(new String(bytes, charset).getBytes(), GlobalConfig.ENCODING);

return StringEscapeUtils.unescapeHtml4(strUtf8);

}

} catch (Exception e) {

logger.error("error! url [" + httpRequest.getUrl() + "]", e);

} finally {

try {

if (httpEntity != null) {

EntityUtils.consume(httpEntity);

}

if (response != null) {

response.close();

}

if (httpGet != null) {

httpGet.abort();

}

} catch (Exception e) {

// ignore

}

}

return null;

}

"pool-1-thread-10" prio=10 tid=0x00007f7168003000 nid=0x3e4d waiting on condition [0x00007f717c398000]

java.lang.Thread.State: WAITING (parking)

at sun.misc.Unsafe.park(Native Method)

- parking to wait for <0x00000000e69d7350> (a java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject)

at java.util.concurrent.locks.LockSupport.park(LockSupport.java:186)

at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await(AbstractQueuedSynchronizer.java:2043)

at org.apache.http.pool.PoolEntryFuture.await(PoolEntryFuture.java:133)

at org.apache.http.pool.AbstractConnPool.getPoolEntryBlocking(AbstractConnPool.java:282)

at org.apache.http.pool.AbstractConnPool.access$000(AbstractConnPool.java:64)

at org.apache.http.pool.AbstractConnPool$2.getPoolEntry(AbstractConnPool.java:177)

at org.apache.http.pool.AbstractConnPool$2.getPoolEntry(AbstractConnPool.java:170)

at org.apache.http.pool.PoolEntryFuture.get(PoolEntryFuture.java:102)

at org.apache.http.impl.conn.PoolingHttpClientConnectionManager.leaseConnection(PoolingHttpClientConnectionManager.jav

a:244)

at org.apache.http.impl.conn.PoolingHttpClientConnectionManager$1.get(PoolingHttpClientConnectionManager.java:231)

at org.apache.http.impl.execchain.MainClientExec.execute(MainClientExec.java:173)

at org.apache.http.impl.execchain.ProtocolExec.execute(ProtocolExec.java:195)

at org.apache.http.impl.execchain.RetryExec.execute(RetryExec.java:86)

at org.apache.http.impl.execchain.RedirectExec.execute(RedirectExec.java:108)

at org.apache.http.impl.client.InternalHttpClient.doExecute(InternalHttpClient.java:184)

at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:82)

at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:106)

怎么解决?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值