java – HttpComponents PoolingHttpClientConnectionManager maxPerRoute和maxTotal?

前端之家收集整理的这篇文章主要介绍了java – HttpComponents PoolingHttpClientConnectionManager maxPerRoute和maxTotal?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
有人可以向我解释一下setMaxPerRoute(max)和setMaxTotal(max)在引用HttpComponents PoolingHttpClientConnectionManager时做了什么?

解决方法

这些设置控制连接池大小.

> setMaxTotal(max)定义连接池的总连接限制.
> setMaxPerRoute(max)定义每个HTTP路由的连接限制.在简单的情况下,您可以将其理解为每个目标主机限制.在引擎盖下,事情更有趣:HttpClient维护了几个HttpRoute对象,它们代表每个主机链,如proxy1 – > proxy2 – > targetHost.连接按路由汇集.在简单的情况下,当您使用默认路由构建机制并且不提供代理支持时,您的路由可能仅包括目标主机,因此每个路由连接池限制实际上变为每个主机限制.

例:

假设你有setMaxPerRoute(5)和setMaxTotal(20).这意味着您可以同时为每个目标主机使用最多5个连接:5个与google.com的连接,另外5个与oracle.com的连接,依此类推.但是,无论您正在与之通信的主机数量是多少,打开的连接总量都不能超过20.

原文链接:https://www.f2er.com/java/123128.html

猜你在找的Java相关文章