加入收藏 | 设为首页 | 会员中心 | 我要投稿 阳江站长网 (https://www.0662zz.cn/)- 办公协同、云通信、区块链、物联平台、高性能计算!
当前位置: 首页 > 站长资讯 > 外闻 > 正文

连接池中非常关键的两个参数

发布时间:2021-03-13 15:50:08 所属栏目:外闻 来源:互联网
导读:xConnectionsPerHost,表示一个连接池中,每条路由,池化的最大连接个数。这个值,默认是2,我看过不少故障是没有设置此值导致的。这个不是我关注的重点,我的疑问是,什么是路由?什么是连接?路由和连接的关系是啥? 首先连接是什么?这个概念很清晰,连接就是

xConnectionsPerHost,表示一个连接池中,每条路由,池化的最大连接个数。这个值,默认是2,我看过不少故障是没有设置此值导致的。这个不是我关注的重点,我的疑问是,什么是路由?什么是连接?路由和连接的关系是啥?

首先连接是什么?这个概念很清晰,连接就是源ip:源端口加目的ip:目的端口,以及相关信息形成的逻辑概念。

那什么是路由呢?我的脑袋,一团混乱。网上也没有比较好的文章,能解答我的疑问。我的猜测是,目的host+port端口就是路由。比如你的项目中需要访问百度。那么baidu.com+80就是一条路由。同时也需要访问csdn,那么csdn.net+80也是一条路由。可是这只是我的猜测。

那看看源码吧。不同版本的http client实现方式是不一样的。我手头的项目有3.x,也有4.x的。我都简单看了下,但是源码都有一个问题是,route的实现类中,既有host,也有localAddress。

至此我们就清晰了,连接池是以host(远端的服务,例如baidu.com)为组,来建立连接池。maxConnectionsPerHost 用来控制一组中连接池的个数,也就是有些同学提到的,用来控制访问某个服务并发的个数。

结论

maxConnectionsPerHost,连接池是以host(远端的服务,例如baidu.com)为组,来建立连接池。此参数用来控制一组中连接池的个数,或者用来控制访问,某个服务并发的个数。

需要注意默认值是2,如果不设置此值。但是流量变大,那么线上故障就会等着你。

(编辑:阳江站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读