自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

連接池中非常關(guān)鍵的兩個(gè)參數(shù),到底是干啥用的?

開(kāi)發(fā) 前端
說(shuō)來(lái)慚愧,從事互聯(lián)網(wǎng)開(kāi)發(fā)好些年了,有些概念一直沒(méi)有徹底搞清楚。其中之一就是,ttp client配置連接池的時(shí)候,maxConnectionsPerHost,和maxTotalConnections,在網(wǎng)上搜了一圈,發(fā)現(xiàn)很多都講的含含糊糊的。

 背景

說(shuō)來(lái)慚愧,從事互聯(lián)網(wǎng)開(kāi)發(fā)好些年了,有些概念一直沒(méi)有徹底搞清楚。其中之一就是,ttp client配置連接池的時(shí)候,maxConnectionsPerHost,和maxTotalConnections,在網(wǎng)上搜了一圈,發(fā)現(xiàn)很多都講的含含糊糊的。而且有不少故障都是這兩個(gè)參數(shù)設(shè)置不合理,或者壓根就沒(méi)有設(shè)置maxConnectionsPerHost等等。

題外話,我記得我剛參加工作的時(shí)候,第一次使用http client。看見(jiàn)項(xiàng)目中,配置的連接池,有maxConnectionsPerHost,我就請(qǐng)教同事,這個(gè)參數(shù)是干啥的。他的答復(fù)是每條路由最大的連接數(shù)。我似懂非懂,但是又不敢多問(wèn),哈哈。

 

分析過(guò)程

maxTotalConnections,很好理解。既然是一個(gè)連接池,那么一個(gè)池子最大能放多少呢?這個(gè)參數(shù)默認(rèn)是20。當(dāng)然這個(gè)參數(shù),在不同的連接池實(shí)現(xiàn)中可能是不一樣,這不是我關(guān)注的重點(diǎn)。

 

連接池中非常關(guān)鍵的兩個(gè)參數(shù),到底是干啥用的?

 

maxConnectionsPerHost,表示一個(gè)連接池中,每條路由,池化的最大連接個(gè)數(shù)。這個(gè)值,默認(rèn)是2,我看過(guò)不少故障是沒(méi)有設(shè)置此值導(dǎo)致的。這個(gè)不是我關(guān)注的重點(diǎn),我的疑問(wèn)是,什么是路由?什么是連接?路由和連接的關(guān)系是啥?

首先連接是什么?這個(gè)概念很清晰,連接就是源ip:源端口加目的ip:目的端口,以及相關(guān)信息形成的邏輯概念。

那什么是路由呢?我的腦袋,一團(tuán)混亂。網(wǎng)上也沒(méi)有比較好的文章,能解答我的疑問(wèn)。我的猜測(cè)是,目的host+port端口就是路由。比如你的項(xiàng)目中需要訪問(wèn)百度。那么baidu.com+80就是一條路由。同時(shí)也需要訪問(wèn)csdn,那么csdn.net+80也是一條路由??墒沁@只是我的猜測(cè)。

那看看源碼吧。不同版本的http client實(shí)現(xiàn)方式是不一樣的。我手頭的項(xiàng)目有3.x,也有4.x的。我都簡(jiǎn)單看了下,但是源碼都有一個(gè)問(wèn)題是,route的實(shí)現(xiàn)類中,既有host,也有l(wèi)ocalAddress。

 

連接池中非常關(guān)鍵的兩個(gè)參數(shù),到底是干啥用的?

 

為了繼續(xù)解答我的疑問(wèn),還是直接debug。簡(jiǎn)單寫(xiě)了一個(gè)單元測(cè)試,類似這樣。

 

連接池中非常關(guān)鍵的兩個(gè)參數(shù),到底是干啥用的?

 

然后我看到了這樣的信息,以3.x源碼為例子,4.x原理是一致的。

 

連接池中非常關(guān)鍵的兩個(gè)參數(shù),到底是干啥用的?

 

獲取連接的過(guò)程,HostConfiguration 雖然其中有本地的地址信息的,但是值是空的。因此route真正起作用的是host。

 

連接池中非常關(guān)鍵的兩個(gè)參數(shù),到底是干啥用的?

 

獲取好連接后,檢查下連接是不是打開(kāi)了,如果沒(méi)有打開(kāi),執(zhí)行open方法,此時(shí)會(huì)設(shè)置localAddress。也就是一條真正的連接才算創(chuàng)建完成。

接下來(lái)我們看下Http的連接池,有數(shù)據(jù)的情況是啥樣。

 

連接池中非常關(guān)鍵的兩個(gè)參數(shù),到底是干啥用的?

 

至此我們就清晰了,連接池是以host(遠(yuǎn)端的服務(wù),例如baidu.com)為組,來(lái)建立連接池。maxConnectionsPerHost 用來(lái)控制一組中連接池的個(gè)數(shù),也就是有些同學(xué)提到的,用來(lái)控制訪問(wèn)某個(gè)服務(wù)并發(fā)的個(gè)數(shù)。

結(jié)論

maxConnectionsPerHost,連接池是以host(遠(yuǎn)端的服務(wù),例如baidu.com)為組,來(lái)建立連接池。此參數(shù)用來(lái)控制一組中連接池的個(gè)數(shù),或者用來(lái)控制訪問(wèn),某個(gè)服務(wù)并發(fā)的個(gè)數(shù)。

需要注意默認(rèn)值是2,如果不設(shè)置此值。但是流量變大,那么線上故障就會(huì)等著你。

責(zé)任編輯:武曉燕 來(lái)源: 今日頭條
相關(guān)推薦

2021-08-13 05:47:48

通信設(shè)計(jì)院通信行業(yè)設(shè)計(jì)院

2010-03-18 14:22:46

Python數(shù)據(jù)庫(kù)連接

2022-09-26 07:08:16

無(wú)線通信CT

2022-04-10 19:26:07

TypeScript類型語(yǔ)法

2024-08-26 14:23:56

2021-12-16 15:11:59

Facebook天秤幣加密貨幣

2022-09-06 21:38:45

數(shù)字人數(shù)字孿生

2024-07-12 15:08:23

Python@wraps函數(shù)

2020-10-25 20:05:29

Pythonyield開(kāi)發(fā)

2021-03-22 07:45:05

Sentinel微服務(wù)開(kāi)源的項(xiàng)目

2022-02-16 20:04:08

容器KubernetesShim

2020-04-22 13:29:35

基帶射頻信號(hào)

2024-02-22 08:00:00

SoraOpenAI

2022-08-08 08:00:00

人工智能機(jī)器學(xué)習(xí)計(jì)算機(jī)應(yīng)用

2022-03-16 00:15:56

Flask擴(kuò)展插件

2024-02-07 12:35:00

React并發(fā)模式concurrent

2012-02-13 15:50:59

2021-01-29 12:24:22

電腦電子計(jì)算機(jī)

2010-03-18 15:09:15

python數(shù)據(jù)庫(kù)連接

2020-09-21 15:16:09

大數(shù)據(jù)IT技術(shù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)