使用PoolingHttpClientConnectionManager解决友…

2018-06-18 03:52:55来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

在友盟(umeng)提供的服务端推送的sdk中,使用的是apache提供的httpclient。在单线程化境下,httpclient工作没有问题。但是由于umeng的sdk中并未考虑并发的情况,因此很有可能你会收到这样的error:

java.lang.IllegalStateException: Invalid use of BasicClientConnManager: connection still allocated.
Make sure to release the connection before allocating another one.

 

在apache提供的httpclient类库中,其实已经提供了对线程池管理的类,比如PoolingHttpClientConnectionManager:

修改umeng sdk中的PushClient.java:

1.由于默认的HttpClient(4.3.5)构造函数已经过期,可以使用下面的方式重新声明:

protected HttpClient client = HttpClients.custom().build();

 

2. 增加一个PushClient的构造函数:

public PushClient() {

ConnectionSocketFactory plainsf = PlainConnectionSocketFactory
.getSocketFactory();
LayeredConnectionSocketFactory sslsf = SSLConnectionSocketFactory
.getSocketFactory();
Registry<ConnectionSocketFactory> registry = RegistryBuilder
.<ConnectionSocketFactory>create().register("http", plainsf)
.register("https", sslsf).build();
PoolingHttpClientConnectionManager cm = new PoolingHttpClientConnectionManager(
registry);
// 将最大连接数增加
cm.setMaxTotal(20);
// 将每个路由基础的连接增加
cm.setDefaultMaxPerRoute(20);

client = HttpClients.custom()
.setConnectionManager(cm).build();
}

完成。

 参考:

HttpClient Examples:http://hc.apache.org/httpcomponents-client-ga/examples.html

 

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:equals、==和hashCode

下一篇:SpringBoot入坑-请求参数传递