理解資料庫連線池底層原理之手寫實現

2021-08-04 19:40:10 字數 3179 閱讀 1348

原文:

資料庫連線池的基本思想是:為資料庫連線建立乙個「緩衝池」,預先在池中放入一定數量的資料庫連線管道,需要時,從池子中取出管道進行使用,操作完畢後,在將管道放入池子中,從而避免了頻繁的向資料庫申請資源,釋放資源帶來的效能損耗。在如今的分布式系統當中,系統的qps瓶頸往往就在資料庫,所以理解資料庫連線池底層構造原理與設計思想是很有益處的。我們常用的資料庫連線池有c3p0,dbcp,druid等,下面我們就來分析下資料庫連線池應該有些什麼,以及手寫乙個迷你版的資料庫連線池!

資料庫連線池

第一,資料庫連線池中存放的就是資料庫操作管道,不僅僅是存放,而且應該是管理這些管道;第二,應該提供外部配置檔案去初始化資料庫連線池;第三,如果乙個資料庫操作管道已經被占用,那麼其他請求是否應該得到這個管道,也就是說我們要考慮多執行緒併發下,管道的分配問題;第四,如果做到管道的復用?放回池子中,標示可用,並不是真正的關閉管道;

工程類關係圖說明

imypool是乙個介面,對外提供資料庫連線池的基本服務,比如得到乙個資料庫操作管道。mydefaultpool是imypool的實現。mypooledconnection代表資料庫操作管道,它可以執行sql,關閉管道等。mypoolfactory是乙個工廠,單例模式,用於得到imypool實現。dbconfigxml代表外部配置檔案。

test用於測試。

我們在實際中使用資料庫連線池,需要在spring的配置檔案中,進行一些引數配置。這裡,為了簡化解析,直接提供。

mypooledconnection

資料庫連線管道

所謂資料庫連線管道,就是對jdbc connection進行封裝而已,但是需要注意isbusy的這個標示。對管道的關閉,實際上只是標示的改變而已!

需要注意到是,mydefaultpool持有乙個管道集合,基於多執行緒的考慮,這裡使用了vector。

mydefaultpool需要初始化

資料庫連線池初始化

資料庫連線池需要根據外部配置檔案完成資料庫驅動載入以及初始化管道的建立。

createmypooledconnection介面實現

建立資料庫連線管道

資料庫連線池在建立管道時,應該去看一下是否達到上限,如果沒有,則可以建立。不僅僅要建立出來,還要標示每乙個管道的isbusy標誌。

getmypooledconnection介面實現

得到資料庫連線管道

這裡需要注意的是:如果得不到操作管道,需要去建立管道!

第一,這裡使用了synchronized,就是為了避免多執行緒下產生問題。第二,要知道connection是有超時機制的,如果我們得到的管道的connection已經超時了怎麼辦呢?第三,得到管道後,一定注意isbusy的設定。

單例工廠

test測試

測試類

執行結果

result

好了,到這裡,乙個迷你版的資料庫連線池就有模有樣了!

早安,上班去了,再見!

資料庫連線池底層原理以及手寫實現

資料庫連線池的基本思想是 為資料庫連線建立乙個 緩衝池 預先在池中放入一定數量的資料庫連線管道,需要時,從池子中取出管道進行使用,操作完畢後,在將管道放入池子中,從而避免了頻繁的向資料庫申請資源,釋放資源帶來的效能損耗。在如今的分布式系統當中,系統的qps瓶頸往往就在資料庫,所以理解資料庫連線池底層...

理解資料庫連線池

下面用乙個簡單的例子來說明下 如下 using system using system.collections.generic using system.componentmodel using system.data using system.drawing using system.linq u...

如何理解 資料庫連線池

對於乙個簡單的資料庫應用,由於對於資料庫的訪問不是很頻繁。這時可以簡單地在需要訪問資料庫時,就新建立乙個連線,用完後就關閉它,這樣做也不會帶來什麼明顯的效能上的開銷。但是對於乙個複雜的資料庫應用,情況就完全不同了。頻繁的建立 關閉連線,會極大的減低系統的效能,因為對於連線的使用成了系統效能的瓶頸。連...