第一,數(shù)據(jù)庫連接池中存放的就是數(shù)據(jù)庫操作管道,不僅僅是存放,而且應(yīng)該是管理這些管道;
第二,應(yīng)該提供外部配置文件去初始化數(shù)據(jù)庫連接池;
第三,如果一個數(shù)據(jù)庫操作管道已經(jīng)被占用,那么其他請求是否應(yīng)該得到這個管道,也就是說我們要考慮多線程并發(fā)下,管道的分配問題;
第四,如果做到管道的復(fù)用?放回池子中,標(biāo)示可用,并不是真正的關(guān)閉管道;
IMyPool是一個接口,對外提供數(shù)據(jù)庫連接池的基本服務(wù),比如得到一個數(shù)據(jù)庫操作管道。
MyDefaultPool是IMyPool的實現(xiàn)。
MyPooledConnection代表數(shù)據(jù)庫操作管道,它可以執(zhí)行SQL,關(guān)閉管道等。
MyPoolFactory是一個工廠,單例模式,用于得到IMyPool實現(xiàn)。
DBConfigXML代表外部配置文件。
Test用于測試。
DBConfigXML
我們在實際中使用數(shù)據(jù)庫連接池,需要在Spring的配置文件中,進(jìn)行一些參數(shù)配置。這里,為了簡化解析,直接提供。
MyPooledConnection
所謂數(shù)據(jù)庫連接管道,就是對JDBC Connection進(jìn)行封裝而已,但是需要注意isBusy的這個標(biāo)示。對管道的關(guān)閉,實際上只是標(biāo)示的改變而已!
IMyPool
MyDefaultPool
需要注意到是,MyDefaultPool持有一個管道集合,基于多線程的考慮,這里使用了Vector。
MyDefaultPool需要初始化
數(shù)據(jù)庫連接池需要根據(jù)外部配置文件完成數(shù)據(jù)庫驅(qū)動加載以及初始化管道的建立
createMyPooledConnection接口實現(xiàn)
數(shù)據(jù)庫連接池在創(chuàng)建管道時,應(yīng)該去看一下是否達(dá)到上限,如果沒有,則可以創(chuàng)建。
不僅僅要創(chuàng)建出來,還要標(biāo)示每一個管道的isBusy標(biāo)志。
getMyPooledConnection接口實現(xiàn)
這里需要注意的是:如果得不到操作管道,需要去創(chuàng)建管道!
getRealConnectionFromPool
第一,這里使用了synchronized,就是為了避免多線程下產(chǎn)生問題。
第二,要知道Connection是有超時機(jī)制的,如果我們得到的管道的Connection已經(jīng)超時了怎么辦呢?
第三,得到管道后,一定注意isBusy的設(shè)置。
MyPoolFactory
Test測試
運(yùn)行結(jié)果
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。