HttpClient连接池设置
说明
在项目中用到httpclient,在性能压测的时候发现,达到一定的并发量的时候系统间的交互延迟会变高,最后定位发现问题出现http连接方面。主要解决措施是设置连接池的最大连接数和路由最大连接数,其余的可以设置超时时间等。
为什么 HttpClient 需要连接池
一次创建连接是一次 TCP 进行三次握手的操作,一次销毁连接是一次 TCP 进行四次挥手的操作。采用连接池技术管理连接,连接可以得到复用,能给减少在创建连接和销毁连接所花的时间,减少服务器资源的消耗,能够达到较高的并发。
HttpClient 连接池的配置
public HttpServiceImpl(BaseProperties baseProperties) {
this.baseProperties = baseProperties;
//将最大连接数增加到200
cm.setMaxTotal(baseProperties.getMaxTotal());
//将每个路由的默认最大连接数增加到20
cm.setDefaultMaxPerRoute(baseProperties.getDefaultMaxPerRoute());
httpClient = HttpClientBuilder.create()
.setConnectionManager(cm)
.build();
}
其余配置可参考博客HttpClient实战:连接池设置