理解數(shù)據(jù)庫連接池底層原理之手寫實現(xiàn)
前言
數(shù)據(jù)庫連接池的基本思想是:為數(shù)據(jù)庫連接建立一個“緩沖池”,預先在池中放入一定數(shù)量的數(shù)據(jù)庫連接管道,需要時,從池子中取出管道進行使用,操作完畢后,在將管道放入池子中,從而避免了頻繁的向數(shù)據(jù)庫申請資源,釋放資源帶來的性能損耗。在如今的分布式系統(tǒng)當中,系統(tǒng)的QPS瓶頸往往就在數(shù)據(jù)庫,所以理解數(shù)據(jù)庫連接池底層構造原理與設計思想是很有益處的。我們常用的數(shù)據(jù)庫連接池有C3P0,DBCP,Druid等,下面我們就來分析下數(shù)據(jù)庫連接池應該有些什么,以及手寫一個迷你版的數(shù)據(jù)庫連接池!
對數(shù)據(jù)庫連接池的一點思考
- ***,數(shù)據(jù)庫連接池中存放的就是數(shù)據(jù)庫操作管道,不僅僅是存放,而且應該是管理這些管道;
- 第二,應該提供外部配置文件去初始化數(shù)據(jù)庫連接池;
- 第三,如果一個數(shù)據(jù)庫操作管道已經(jīng)被占用,那么其他請求是否應該得到這個管道,也就是說我們要考慮多線程并發(fā)下,管道的分配問題;
- 第四,如果做到管道的復用?放回池子中,標示可用,并不是真正的關閉管道;
寫一個迷你版數(shù)據(jù)庫連接池

- IMyPool是一個接口,對外提供數(shù)據(jù)庫連接池的基本服務,比如得到一個數(shù)據(jù)庫操作管道。
- MyDefaultPool是IMyPool的實現(xiàn)。
- MyPooledConnection代表數(shù)據(jù)庫操作管道,它可以執(zhí)行SQL,關閉管道等。
- MyPoolFactory是一個工廠,單例模式,用于得到IMyPool實現(xiàn)。
- DBConfigXML代表外部配置文件。
- Test用于測試。
DBConfigXML

- 我們在實際中使用數(shù)據(jù)庫連接池,需要在Spring的配置文件中,進行一些參數(shù)配置。這里,為了簡化解析,直接提供。
MyPooledConnection

- 所謂數(shù)據(jù)庫連接管道,就是對JDBC Connection進行封裝而已,但是需要注意isBusy的這個標示。對管道的關閉,實際上只是標示的改變而已!
IMyPool

MyDefaultPool

- 需要注意到是,MyDefaultPool持有一個管道集合,基于多線程的考慮,這里使用了Vector。
MyDefaultPool需要初始化

- 數(shù)據(jù)庫連接池需要根據(jù)外部配置文件完成數(shù)據(jù)庫驅(qū)動加載以及初始化管道的建立。
createMyPooledConnection接口實現(xiàn)

- 數(shù)據(jù)庫連接池在創(chuàng)建管道時,應該去看一下是否達到上限,如果沒有,則可以創(chuàng)建。
- 不僅僅要創(chuàng)建出來,還要標示每一個管道的isBusy標志。
getMyPooledConnection接口實現(xiàn)

- 這里需要注意的是:如果得不到操作管道,需要去創(chuàng)建管道!
getRealConnectionFromPool

- ***,這里使用了synchronized,就是為了避免多線程下產(chǎn)生問題。
- 第二,要知道Connection是有超時機制的,如果我們得到的管道的Connection已經(jīng)超時了怎么辦呢?
- 第三,得到管道后,一定注意isBusy的設置。
MyPoolFactory

Test測試

運行結果

理解數(shù)據(jù)庫連接池底層原理之手寫實現(xiàn)
好了,到這里,一個迷你版的數(shù)據(jù)庫連接池就有模有樣了!


























