国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

DataSource,一個被嚴(yán)重低估的接口

數(shù)據(jù)庫 其他數(shù)據(jù)庫
文章使用循序漸進(jìn)的方式,幫助大家梳理了一遍 DataSource 產(chǎn)出背景,講述了 jdbc 1.0 版本獲取數(shù)據(jù)庫連接的方式 DriverManager,發(fā)展到 2.0 后的 DataSource,以及其中引入的數(shù)據(jù)庫連接池技術(shù).

[[400807]]

產(chǎn)出背景

最近這段時間一直忙著集團(tuán)內(nèi)部安全等保加密相關(guān)事項,初步?jīng)Q定使用 shardingsphere 來進(jìn)行

因為項目眾多,需要兼容的需求也隨之而來,加密數(shù)據(jù)源和動態(tài)數(shù)據(jù)源的互相兼容,以及分庫分表和加密數(shù)據(jù)源的兼容等等,反正一言不合就兼容

無疑,上面這些或多或少都和數(shù)據(jù)源有關(guān)系,所以在處理不同兼容性等問題時,也讓我再次對 DataSource 產(chǎn)生了了解的興趣,這個曾經(jīng)被很多人遺忘的重要概念

老時代的數(shù)據(jù)查詢

在很久很久以前(反正忘了多久),那個時候應(yīng)用程序連接數(shù)據(jù)庫還是這么個操作

可以清楚的看到,曾經(jīng)獲取數(shù)據(jù)庫連接的代碼還需要使用 DriverManager,大家都清楚,DriverManager#getConnection 是通過數(shù)據(jù)庫驅(qū)動直接與數(shù)據(jù)庫建立連接

建立數(shù)據(jù)庫連接以及關(guān)閉連接屬于耗費(fèi)時間的事情,如果業(yè)務(wù)層每次進(jìn)行 SQL 查詢都使用此方式,將會產(chǎn)生較大的系統(tǒng)開銷

一般系統(tǒng)的性能要求,單次請求需要穩(wěn)定在 200 ms。經(jīng)過在本地環(huán)境測試,DriverManager 形式創(chuàng)建數(shù)據(jù)庫連接需要 300~500 ms 左右,健身五分鐘,拍照兩小時?

[[400808]]

隨著系統(tǒng)的發(fā)展迭代,出于 系統(tǒng)的復(fù)雜度以及對性能的要求,這種獲取連接的方式是難以接受的

連接池的出現(xiàn)

相信有些讀者能夠聯(lián)想出來,數(shù)據(jù)庫連接創(chuàng)建消耗資源這個場景好像在哪聽過,沒錯,和線程創(chuàng)建的情況基本類似。既然線程可以用線程池關(guān)聯(lián),那數(shù)據(jù)庫連接是不是可以放到一個池子中?

是的,還真有存放數(shù)據(jù)庫連接的池化技術(shù),叫做 連接池。應(yīng)用程序從連接池中獲取數(shù)據(jù)庫連接,使用過再放到池子里,是不是感覺很 Nice?完美的解決了重復(fù)創(chuàng)建消耗資源的情況

看似完美的背后,其實還存在一個致命的問題,那就是最開始去連接池中獲取連接時,連接池中是沒有連接的,還需要走創(chuàng)建流程

連接池是怎么解決這一問題呢?通過創(chuàng)建連接池時初始化其中的連接,一般連接池都有這樣一個參數(shù) initialSize,代表池子中初始化的連接數(shù)量

下圖是 Druid 在執(zhí)行 init 方法時數(shù)據(jù)庫連接初始化的流程,當(dāng)初始化連接小于池內(nèi)連接時,進(jìn)行循環(huán)創(chuàng)建,直到池內(nèi)連接滿足初始化數(shù)量

連接池、線程池...這些池化技術(shù)的核心思想就是 空間換取時間。因為在絕大數(shù)情況下,空間并沒有那么稀缺,我們更關(guān)心的是系統(tǒng)的性能

數(shù)據(jù)源登場

連接池雖然 🐂 🍺 ,但是獨(dú)木難支。連接池沒有產(chǎn)生連接的能力,所以還需要配合類似 DriverManager 組件與數(shù)據(jù)庫驅(qū)動配合創(chuàng)建連接。如果這樣放到業(yè)務(wù)代碼里,那豈不是還得封裝一層?

這個時候,不約而同的想到一個公司,sun 公司是干啥的?制定規(guī)范的對不對,他們在 jdbc 2.0 版本推出一個 DataSource 的東東,用來進(jìn)行規(guī)范約束訪問數(shù)據(jù)庫的流程

相當(dāng)于把 DriverManager 和連接池概念揉合在一起,如果你想獲取數(shù)據(jù)庫連接,你通過我 DataSource 獲取,你不用關(guān)心連接池和數(shù)據(jù)庫連接怎么創(chuàng)建的,用就完了,使用完也不用關(guān)閉連接。其實,DataSource 獲取的連接來自于連接池,而連接池的連接其實還是從 DriverManager或類似組件中創(chuàng)建的

DriverManager 只是 jdbc 1.0 版本用來調(diào)用數(shù)據(jù)庫驅(qū)動的的工具包,jdbc 2.0 版本推出 DataSource 之后,典型的像 DruidDataSource 就沒有依賴 DriverManager,而是在自己實現(xiàn)類中調(diào)用了數(shù)據(jù)庫驅(qū)動。這里只是重點(diǎn)強(qiáng)調(diào),數(shù)據(jù)庫連接不一定是使用 DriverManager 創(chuàng)建

總結(jié)下,數(shù)據(jù)源(DataSource)是 sun 公司指定用于獲取數(shù)據(jù)庫連接的規(guī)范接口,應(yīng)用程序于數(shù)據(jù)庫連接抽象的中間層,它存在于 javax.sql 包,用來代替 DriverManager 的方式獲取數(shù)據(jù)庫連接

使用 DataSource 比 DriverManager 到底有什么好處呢

DriverManager

在應(yīng)用程序里創(chuàng)建/關(guān)閉連接時會妨礙應(yīng)用程序性能

不支持連接池,重復(fù)創(chuàng)建/關(guān)閉連接,浪費(fèi)系統(tǒng)性能

DataSource

由于不在應(yīng)用程序中創(chuàng)建/關(guān)閉連接,可以很好的提高應(yīng)用程序性能

提供了連接池的功能,避免重復(fù)創(chuàng)建

這里畫一張圖來描述下,針對應(yīng)用程序使用 DataSource 和 DriverManager 獲取連接的不同

有了 DataSource 之后,數(shù)據(jù)庫連接、用戶名、密碼都進(jìn)行了統(tǒng)一的管理,作為 DataSource 屬性的一部分,并且將數(shù)據(jù)庫驅(qū)動名稱填充,底層自動加載

DataSource 技術(shù)解析

我們先來看下 DataSource 的接口描述以及對應(yīng)的方法,先初步進(jìn)行了解

DataSource 中只有兩個接口,是一個重載的關(guān)系,用于建立 DataSource 所代表數(shù)據(jù)源的數(shù)據(jù)庫連接

這里應(yīng)該注意的是 CommonDataSource 接口,公共數(shù)據(jù)源接口用來定義以下三個數(shù)據(jù)源接口的公共方法

javax.sql.DataSource:定義基礎(chǔ)獲取數(shù)據(jù)庫連接的接口

javax.sql.ConnectionPoolDataSource:定義從數(shù)據(jù)庫連接池中獲取連接的接口

javax.sql.XADataSource:定義獲取分布式事務(wù)連接的接口。一般少有直接使用 XA 分布式事務(wù),具體原因參考 分布式 2PC、3PC 事務(wù)模型

第一、二種就比較容易理解,sun 公司定義規(guī)范時,就是希望你 普通獲取數(shù)據(jù)庫連接使用 DataSource,數(shù)據(jù)源底層如果是連接池那么使用 ConnectionPoolDataSource

后面發(fā)展逐漸脫離了原本的軌道預(yù)期,比如 DruidDataSource 就同時實現(xiàn)了兩者,類圖如下

其實這樣也沒啥事,DruidDataSource 一個類包裝兩種 DataSource 接口實現(xiàn),這種方式對于使用者是無感知的

完事總結(jié)

文章使用循序漸進(jìn)的方式,幫助大家梳理了一遍 DataSource 產(chǎn)出背景

講述了 jdbc 1.0 版本獲取數(shù)據(jù)庫連接的方式 DriverManager,發(fā)展到 2.0 后的 DataSource,以及其中引入的數(shù)據(jù)庫連接池技術(shù)

相信讀者看完對 DataSource 應(yīng)該有了更深入的了解,感興趣的讀者可以去研讀 Hikari 和 Druid 實現(xiàn)的數(shù)據(jù)源,通過閱讀源碼的方式能夠更好的理解 DataSource 設(shè)計思路

 

責(zé)任編輯:姜華 來源: 龍臺的技術(shù)筆記
相關(guān)推薦

2023-02-14 07:50:30

Python模塊

2013-06-28 17:28:04

推送

2023-11-09 09:02:26

TypeScriptas const

2021-04-21 09:19:44

裝飾器Python

2024-12-13 08:02:10

PythonGenerator懶加載

2025-11-20 14:02:39

2023-01-16 18:16:49

CinnamonLinux桌面環(huán)境

2025-03-25 09:20:00

NPM庫開發(fā)代碼

2013-01-14 09:36:54

程序員程序員價值

2016-01-27 13:40:12

IBM Watson/

2024-10-21 13:11:50

2022-11-03 11:23:33

阿里云云計算

2020-07-13 07:27:16

Python開發(fā)

2022-09-16 09:13:27

代碼偷懶方法

2020-10-04 11:34:28

JavaScript開發(fā)技術(shù)

2025-09-23 01:00:00

JavaScript性能堆棧

2020-11-30 22:50:48

AWS服務(wù)云計算

2024-12-03 16:39:41

2024-06-06 10:13:04

2022-11-10 08:31:09

原生圖數(shù)據(jù)庫可視化
點(diǎn)贊
收藏

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

毛片在线播放网址| 四虎成人精品一区二区免费网站| 国产成人精品网址| 国产成人精品久久| 蜜桃成人精品| 日韩欧美你懂的| 四虎精品在线| 亚洲国产中文字幕| jizzzz日本| 久久夜色精品国产噜噜av| 乱熟女高潮一区二区在线| 日韩av一区二区在线影视| 51精品国产人成在线观看| 日韩美女毛片| 久久精品久久久久| 在线日本欧美| 一本色道久久88综合日韩精品| 久久黄色美女电影| 91福利在线看| 懂色av中文在线| 欧美在线一区二区| 黄色av免费在线观看| 懂色aⅴ精品一区二区三区蜜月| 69ww免费视频播放器| 99国产精品久| 国产一区二区在线视频播放| 暴力调教一区二区三区| 免费观看亚洲视频| 99精品久久久久久| 日韩福利视频在线| 国产精品视频免费看| 五月天电影免费在线观看一区| 中文字幕精品综合| 97超碰在线资源站| 亚洲男女一区二区三区| 国产剧情av在线| 亚洲精品国产无天堂网2021| 成年人视频在线网站| 午夜精品久久久| 在线看的av网站| 日韩精品一区二区三区swag| 亚洲一区资源| 欧美激情一区二区三区在线视频观看| 一区二区三区四区高清视频| 日本精品久久中文字幕佐佐木| 天天久久综合| 欧美尤物一区| 91天堂素人约啪| 国产福利电影网| 欧美日韩国产综合一区二区三区| 成全电影大全在线观看| 久久久国产精品视频| 亚洲香蕉视频| 久久综合一区二区三区| 狠狠色狠狠色综合| 黑森林福利视频导航| 亚洲三级久久久| 国产黄在线观看免费观看不卡| 欧美二区乱c少妇| 日韩欧美另类一区二区| 1769国内精品视频在线播放| 欧美日本一区| 久久久久久久9| 亚洲精品欧美综合四区| 成人三级黄色免费网站| 亚洲视频在线播放| 免费成人av| 亚洲日本精品| 亚洲欧美日韩中文播放| 成人在线观看免费网站| 欧美成人在线免费| 99国产成+人+综合+亚洲欧美| 欧美精品自拍视频| 亚洲午夜三级在线| 欧美巨大丰满猛性社交| 国产成人av网| 国产在线国偷精品产拍免费yy| 日本加勒比高清在线| 在线成人免费观看| 超碰成人97| 亚洲一区免费看| 亚洲一区在线观看视频| 午夜久久中文| 国产精品香蕉国产| 成人丝袜视频网| 国产在线观看免费| 久久久综合免费视频| 久久久久久9| 国产女主播在线| 亚洲一级一级97网| 亚洲欧洲日本mm| 先锋影音资源综合在线播放av| 亚洲国产成人精品女人久久久 | 国产精品区一区二区三在线播放| 99re亚洲国产精品| 在线播放麻豆| 国产福利视频一区| 26uuu亚洲综合色| 女同一区二区免费aⅴ| 成人免费网视频| 国产精品久久久久久妇女6080| 亚洲精品**中文毛片| 国产精品传媒毛片三区| 怡红院av一区二区三区| 啪啪av大全导航福利综合导航| 欧美激情第六页| 亚洲国产毛片aaaaa无费看| 日韩精品第二页| 国产免费色视频| 欧美精品在线观看播放| 99精品在线观看| 高潮白浆视频| 久久久久久午夜| 久久午夜羞羞影院免费观看| 69久成人做爰电影| 午夜一区二区三区| 日韩一区二区在线观看视频| 亚洲香蕉网站| 欧美精品a∨在线观看不卡 | 欧美在线一区二区三区四区| 欧美午夜精品久久久久久久| 大奶在线精品| 男女午夜激情视频| 久久亚洲成人精品| 成人精品视频一区二区三区尤物| 91jq激情在线观看| 日韩一区二区三区资源| 在线不卡的av| 久久国产精品99国产| 麻豆电影在线播放| 久久手机视频| 色综合天天综合网天天看片| 日韩精品永久网址| 一级片免费在线观看| 91网在线免费观看| 色婷婷亚洲一区二区三区| 欧美成人综合| www.在线视频.com| 日本精品一区二区三区高清 久久 日本精品一区二区三区不卡无字幕 | 国内自拍中文字幕| 亚洲色图在线观看| av日韩在线网站| 亚洲毛片在线免费| 久草青青在线观看| 欧美风情在线观看| 亚洲美女淫视频| 99久久.com| 欧洲不卡av| 国产精品av免费| www国产精品视频| 亚洲国产电影在线观看| 丝袜美腿一区二区三区动态图| 免费免费啪视频在线观看| 欧美一级淫片丝袜脚交| 亚洲高清免费观看高清完整版在线观看| 成人网18免费网站| 中文字幕在线视频网| 国产精品毛片va一区二区三区| 欧美电影影音先锋| 韩国毛片一区二区三区| 中文字幕成人| 国产经典一区| 男人的天堂狠狠干| 豆国产97在线| 亚洲欧美在线第一页| 亚洲成人网av| 日本网站在线观看一区二区三区| 日本高清在线观看| 欧美中文字幕在线观看视频 | 你懂的网址国产 欧美| 黄色片网站在线| 国产精品av免费观看| 性色av香蕉一区二区| 色综合 综合色| 国产综合色产在线精品| 国产一级成人av| 成人动漫在线免费观看| 欧美日韩中文字幕在线播放| 97久久精品在线| 欧美日韩一二三| 91免费在线看| 欧美在线播放| avav成人| 欧美日韩国产中文字幕在线| 国产又爽又黄ai换脸| 日本伊人精品一区二区三区介绍| 欧美色综合天天久久综合精品| 成人精品鲁一区一区二区| 婷婷丁香综合| 日日夜夜综合| 最新真实国产在线视频| 欧美一级片中文字幕| 国产麻豆日韩| 欧美成人h版在线观看| 欧美乱妇15p| 国产精品久久久久久久久免费相片 | 欧美亚洲黄色| 黄色在线网站| aaa毛片在线观看| 久久天天狠狠|