99国产精品欲av蜜臀,可以直接免费观看的AV网站,gogogo高清免费完整版,啊灬啊灬啊灬免费毛片

網(wǎng)易首頁 > 網(wǎng)易號 > 正文 申請入駐

為什么數(shù)據(jù)庫連接池不采用 IO 多路復(fù)用?

0
分享至

今天,今天我們聊一個(gè)不常見的 Java 面試題:為什么數(shù)據(jù)庫連接池不采用 IO 多路復(fù)用?

這是一個(gè)非常好的問題。IO多路復(fù)用被視為是非常好的性能助力器。但是一般我們在使用 DB 時(shí),還是經(jīng)常性采用c3p0tomcat connection pool等技術(shù)來與 DB 連接,哪怕整個(gè)程序已經(jīng)變成以Netty為核心。這到底是為什么?

首先糾正一個(gè)常見的誤解。IO多路復(fù)用聽上去好像是多個(gè)數(shù)據(jù)可以共享一個(gè)IO(socket連接),實(shí)際上并非如此。「IO多路復(fù)用不是指多個(gè)服務(wù)共享一個(gè)連接,而僅僅是指多個(gè)連接的管理可以在同一進(jìn)程」。在網(wǎng)絡(luò)服務(wù)中,IO多路復(fù)用起的作用是「一次性把多個(gè)連接的事件通知業(yè)務(wù)代碼處理」。至于這些事件的處理方式,到底是業(yè)務(wù)代碼循環(huán)著處理、丟到隊(duì)列里,還是交給線程池處理,由業(yè)務(wù)代碼決定。

對于使用DB的程序來講,不管使用多路復(fù)用,還是連接池,都要維護(hù)一組網(wǎng)絡(luò)連接,支持并發(fā)的查詢。

為什么并發(fā)查詢一定要使用多個(gè)連接才能完成呢?因?yàn)镈B一般是使用連接作為Session管理的基本單元。在一個(gè)連接中,SQL語句的執(zhí)行必須是串行、同步的。這是由于對于每一個(gè)Session,DB都要維護(hù)一組狀態(tài)來支持查詢,比如事務(wù)隔離級別,當(dāng)前Session的變量等。只有單Session內(nèi)串行執(zhí)行,才能維護(hù)查詢的正確性(試想一下一組sql在不斷的增減變量,然后這組sql亂序執(zhí)行會(huì)發(fā)生什么)。維護(hù)這些狀態(tài)需要耗費(fèi)內(nèi)存,同時(shí)也會(huì)消耗CPU和磁盤IO。這樣,限制對DB的連接數(shù),就是在限制對DB資源的消耗。

因此,對DB來說,關(guān)鍵是要限制連接的數(shù)目。這個(gè)要求無論是DB連接池還是NIO的連接管理都能做到。

這樣問題就繞回來了,為什么DB連接不能放到IO多路復(fù)用里一并執(zhí)行嗎?為啥大家都用連接池?

答案是,可以用IO多路復(fù)用——但是「使用JDBC不行」。JDBC是一個(gè)出現(xiàn)了近20年的標(biāo)準(zhǔn),它的設(shè)計(jì)核心是BIO(因?yàn)?99X年時(shí)還沒有別的IO可以用):調(diào)用者在通過JDBC時(shí)執(zhí)行比如query這樣的API,在沒有執(zhí)行完成之前,整個(gè)調(diào)用線程被卡住。而類似于Mysql Connector/J這樣的driver完備的實(shí)現(xiàn)了這套語義。

當(dāng)然如果DB Client的協(xié)議的連接處理和解析稍微改一下:

  1. 將IO模式調(diào)整為Non-Blocking,這樣就可以掛到IO多路復(fù)用的內(nèi)核上(select、epoll、kqueue……)

  2. 在Non-Blocking實(shí)現(xiàn)的基礎(chǔ)之上實(shí)現(xiàn)數(shù)據(jù)庫協(xié)議的編碼和解析

就可以實(shí)現(xiàn)用IO多路復(fù)用來訪問DB。實(shí)際上很多其他語言/框架里都是這么干的。比如 Nodejs,see https://github.com/sidorares/node-mysql2;或者 Vert.X 的 db 客戶端https://github.com/mauricio/postgresql-async,不要在意這個(gè)名字,它實(shí)際上同時(shí)支持mysql和postgres)。只不過對于IO多路復(fù)用,數(shù)據(jù)庫官方似乎都沒做這種支持——他們只支持JDBC、ODBC等等這些標(biāo)準(zhǔn)協(xié)議。

那么為什么基于 IO 多路復(fù)用的實(shí)現(xiàn)不能成為默認(rèn)的,官方的,而要成為偏門呢?

對于數(shù)據(jù)庫開發(fā)者來說。這種用法在整體的用戶里占有量非常小,所以也許不值當(dāng)?shù)幕ù罅狻V恍枰褏f(xié)議寫清楚(比如https://dev.mysql.com/doc/internals/en/client-server-protocol.html),就可以做實(shí)現(xiàn)。那么社區(qū)的有興趣的人自然就可以去做。

另外一個(gè)原因是體系的支持。簡單來講,如果沒有一個(gè)大的 Reactive 的運(yùn)行環(huán)境,IO 多路復(fù)用的使用會(huì)非常受限。

IO 多路復(fù)用之所以能成立,是需要「整個(gè)程序要有一個(gè)IO多路復(fù)用的驅(qū)動(dòng)代碼」——就是 select 那句調(diào)用——等待事件來臨,一個(gè) blocking 的 API。整個(gè)程序必須以這個(gè)驅(qū)動(dòng)代碼為核心。這樣就對整個(gè)代碼的結(jié)構(gòu)產(chǎn)生重大的影響。這種影響是沒法用簡單的接口抽象的。

Java Web 容器之所以可以使用 NIO 是因?yàn)?NIO 可以被封裝到容器內(nèi)部。Web 容器對外暴露的還是傳統(tǒng)的多線程形式的Java EE接口。

如果 DB 和 Web 容器同時(shí)使用 NIO,那么調(diào)用的DB連接庫與必須與容器有一個(gè)約定描述「DB的連接管理如何接入Web容器的NIO的驅(qū)動(dòng)代碼」。在 Java 這個(gè)大環(huán)境下,不同人,不同的容器寫的代碼不同;又或者,不使用任何常見的容器,而是自己用 NIO 去封裝一個(gè)。這樣是無法形成代碼上的約定的。那么多個(gè)獨(dú)立的組件就不能很好的共享 NIO 的驅(qū)動(dòng)代碼。

上面這個(gè)用法假設(shè)整個(gè)程序應(yīng)該共享一個(gè) NIO 驅(qū)動(dòng)代碼。那么 Web 和 DB 可不可以各用各的呢?也是可以的,但是為了保證這兩個(gè) NIO 驅(qū)動(dòng)代碼不會(huì)相互 block,最好要分開兩個(gè)線程。這樣一來就會(huì)打破一般 Web 服務(wù)一個(gè)請求處理用一個(gè)線程的一般做法,會(huì)讓程序邊的更復(fù)雜——你的業(yè)務(wù)代碼和DB查詢之間必須做跨線程數(shù)據(jù)交換。

相反,連接池的實(shí)現(xiàn)就相對獨(dú)立的多,也簡單的多。外界只要配好 DB URL,用戶名密碼和連接池的容量參數(shù),就可以做到自行管理連接。

NodejsVert.X是完全不同的。他們本質(zhì)就是Reactive的。他們的NIO的驅(qū)動(dòng)方式是其運(yùn)行時(shí)的基礎(chǔ)——所有要在這個(gè)基礎(chǔ)上開發(fā)的代碼都必須遵守同樣的NIO+異步開發(fā)規(guī)范,使用同一個(gè)NIO的驅(qū)動(dòng)。這樣DBNIO的協(xié)作就不成問題了。

最后,「有大量場景是需要BIO的DB查詢支持的」。批處理數(shù)據(jù)分析代碼都是這樣的場景。這樣的程序?qū)懗蒒IO就會(huì)得不償失——代碼不容易懂,也沒有任何效率上的優(yōu)勢。類似于Nodejs這樣的運(yùn)行時(shí)在此場景下,反而要利用async或等價(jià)的語法來讓代碼看起來是同步的,這樣才容易寫。

總結(jié)一下。DB 訪問一般采用連接池這種現(xiàn)象是生態(tài)造成的。歷史上的 BIO + 連接池的做法經(jīng)過多年的發(fā)展,已經(jīng)解決了主要的問題。在 Java 的大環(huán)境下,這個(gè)方案是非常靠譜的,成熟的。而基于 IO 多路復(fù)用的方式盡管在性能上可能有優(yōu)勢,但是其對整個(gè)程序的代碼結(jié)構(gòu)要求過多,過于復(fù)雜。當(dāng)然,如果有特定的需要,希望使用 IO 多路復(fù)用管理 DB 連接,是完全可行的。

來源:zhihu.com/question/23084473

END

2022年Java原創(chuàng)面試題庫連載中

更多內(nèi)容,點(diǎn)擊上方名片查看

特別聲明:以上內(nèi)容(如有圖片或視頻亦包括在內(nèi))為自媒體平臺“網(wǎng)易號”用戶上傳并發(fā)布,本平臺僅提供信息存儲服務(wù)。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相關(guān)推薦
熱點(diǎn)推薦
留學(xué)圈的話到底有多炸裂?網(wǎng)友:在日本生活5年,我陪她墮了3次胎

留學(xué)圈的話到底有多炸裂?網(wǎng)友:在日本生活5年,我陪她墮了3次胎

解讀熱點(diǎn)事件
2025-07-23 00:10:03
易中天:不殺,留著終是個(gè)危險(xiǎn)

易中天:不殺,留著終是個(gè)危險(xiǎn)

尚曦讀史
2025-07-23 01:45:02
特朗普這話一出,菲律賓總統(tǒng)臉色變了....

特朗普這話一出,菲律賓總統(tǒng)臉色變了....

環(huán)球時(shí)報(bào)新聞
2025-07-23 11:38:05
曝山東男籃簽下奧拉迪波,邱彪這是在干啥?難怪楊鳴出言不遜

曝山東男籃簽下奧拉迪波,邱彪這是在干啥?難怪楊鳴出言不遜

姜大叔侃球
2025-07-23 16:14:29
2025年高考分?jǐn)?shù)線猛跌的4所211大學(xué),400多分成功撿漏,實(shí)屬罕見

2025年高考分?jǐn)?shù)線猛跌的4所211大學(xué),400多分成功撿漏,實(shí)屬罕見

教育導(dǎo)向分享
2025-07-22 19:25:20
我是正師級軍官,參加同學(xué)聚會(huì)被初戀嘲笑,第二年我轉(zhuǎn)業(yè)任副市長

我是正師級軍官,參加同學(xué)聚會(huì)被初戀嘲笑,第二年我轉(zhuǎn)業(yè)任副市長

喬生桂
2025-07-22 17:09:49
涼爽倒計(jì)時(shí)!湖北連發(fā)38條預(yù)警,即將重回40℃!

涼爽倒計(jì)時(shí)!湖北連發(fā)38條預(yù)警,即將重回40℃!

極目新聞
2025-07-23 12:31:27
首次,2名中國大陸出身的華人當(dāng)選為日本參議院議員

首次,2名中國大陸出身的華人當(dāng)選為日本參議院議員

徐靜波靜說日本
2025-07-23 07:24:02
梁朝偉和湯唯在《色戒》里“假戲真做”?網(wǎng)友爆出截圖:一目了然

梁朝偉和湯唯在《色戒》里“假戲真做”?網(wǎng)友爆出截圖:一目了然

姜糖先生
2025-06-08 19:31:00
央視曝光!你以為沒壞實(shí)際早已“細(xì)菌爆表”的5種食物,趕緊扔了

央視曝光!你以為沒壞實(shí)際早已“細(xì)菌爆表”的5種食物,趕緊扔了

阿傖說事
2025-07-22 08:00:09
二手房拋售狂潮席卷全國:我們制造史詩級變革?將會(huì)有什么結(jié)果

二手房拋售狂潮席卷全國:我們制造史詩級變革?將會(huì)有什么結(jié)果

小白鴿財(cái)經(jīng)
2025-07-21 08:36:15
“絕經(jīng)和出道同時(shí)來?”上海街頭驚現(xiàn)她的巨幅海報(bào)!網(wǎng)友:笑著笑著就哭了

“絕經(jīng)和出道同時(shí)來?”上海街頭驚現(xiàn)她的巨幅海報(bào)!網(wǎng)友:笑著笑著就哭了

環(huán)球網(wǎng)資訊
2025-07-23 10:48:19
免費(fèi)領(lǐng)雞蛋,騙244億養(yǎng)老錢!中國老年人“第一大忽悠”終于倒了

免費(fèi)領(lǐng)雞蛋,騙244億養(yǎng)老錢!中國老年人“第一大忽悠”終于倒了

新語愛八卦
2025-07-22 17:59:09
5年7500萬!曝比亞迪已暫停贊助國足:因大量球迷抵制國足贊助商

5年7500萬!曝比亞迪已暫停贊助國足:因大量球迷抵制國足贊助商

風(fēng)過鄉(xiāng)
2025-07-22 20:57:26
實(shí)錘?網(wǎng)傳杜建英有丈夫,還有一個(gè)36歲大兒子,宗慶后竟然是三哥

實(shí)錘?網(wǎng)傳杜建英有丈夫,還有一個(gè)36歲大兒子,宗慶后竟然是三哥

壹月情感
2025-07-20 22:06:40
NBA歷史僅10人能在出戰(zhàn)400+場比賽保持70+%勝率 小卡是現(xiàn)役唯一

NBA歷史僅10人能在出戰(zhàn)400+場比賽保持70+%勝率 小卡是現(xiàn)役唯一

直播吧
2025-07-23 19:09:16
宗馥莉叔叔宗澤后接受巴倫中文網(wǎng)獨(dú)家采訪,又爆出猛料,令人深思

宗馥莉叔叔宗澤后接受巴倫中文網(wǎng)獨(dú)家采訪,又爆出猛料,令人深思

悠閑歷史
2025-07-23 15:55:02
北京化工大學(xué)碳纖維錄取通知書能切西瓜,學(xué)校招生辦:本科生專屬,明年不再沿用

北京化工大學(xué)碳纖維錄取通知書能切西瓜,學(xué)校招生辦:本科生專屬,明年不再沿用

極目新聞
2025-07-23 13:36:32
宮魯鳴或卸任,女籃新帥或敲定,62歲,名宿,或成李夢回歸關(guān)鍵

宮魯鳴或卸任,女籃新帥或敲定,62歲,名宿,或成李夢回歸關(guān)鍵

東球弟
2025-07-23 11:10:02
央視曝光!又一灰色產(chǎn)業(yè)鏈暴雷!0成本套現(xiàn)48萬,還不用還?

央視曝光!又一灰色產(chǎn)業(yè)鏈暴雷!0成本套現(xiàn)48萬,還不用還?

大魚簡科
2025-07-23 16:17:38
2025-07-23 20:08:49
Meta
Meta
關(guān)注java進(jìn)階架構(gòu)師送架構(gòu)
1059文章數(shù) 9856關(guān)注度
往期回顧 全部

科技要聞

別自嗨了!XREAL徐馳:AI眼鏡只有5歲智商

頭條要聞

印度、孟加拉關(guān)切雅魯藏布江下游水電站工程 中方回應(yīng)

頭條要聞

印度、孟加拉關(guān)切雅魯藏布江下游水電站工程 中方回應(yīng)

體育要聞

英格蘭最紅球星 也是加勒比島國驕傲

娛樂要聞

汪峰森林北同游日本 各帶各娃互不耽誤

財(cái)經(jīng)要聞

律師解析娃哈哈遺產(chǎn)案:遺囑是最大變數(shù)

汽車要聞

德系大招放盡 場地極限測試全新奧迪A5L

態(tài)度原創(chuàng)

藝術(shù)
健康
房產(chǎn)
教育
公開課

藝術(shù)要聞

故宮珍藏的墨跡《十七帖》,比拓本更精良,這才是地道的魏晉寫法

呼吸科專家破解呼吸道九大謠言!

房產(chǎn)要聞

海南自由貿(mào)易港全島封關(guān),2025年12月18日正式啟動(dòng)!

教育要聞

2025年天津高考提前批投檔線分析:中國民航大學(xué)訂單班受熱捧

公開課

李玫瑾:為什么性格比能力更重要?

無障礙瀏覽 進(jìn)入關(guān)懷版 主站蜘蛛池模板: 乐亭县| 年辖:市辖区| 鄂托克旗| 阳泉市| 金川县| 措勤县| 运城市| 仪征市| 驻马店市| 江北区| 固镇县| 石城县| 云和县| 湖州市| 泰兴市| 鄂托克旗| 承德县| 巴林右旗| 滦南县| 剑阁县| 石门县| 郎溪县| 山阴县| 喀什市| 青海省| 景洪市| 双峰县| 吴江市| 景宁| 隆林| 沐川县| 新乐市| 剑阁县| 娱乐| 宁陕县| 鹿邑县| 平定县| 鹤壁市| 张家川| 云浮市| 鲜城|