真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

理解數(shù)據(jù)庫連接池底層原理之手寫實(shí)現(xiàn)

理解數(shù)據(jù)庫連接池底層原理之手寫實(shí)現(xiàn)

為道外等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及道外網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為網(wǎng)站建設(shè)、網(wǎng)站制作、道外網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!

第一,數(shù)據(jù)庫連接池中存放的就是數(shù)據(jù)庫操作管道,不僅僅是存放,而且應(yīng)該是管理這些管道;

第二,應(yīng)該提供外部配置文件去初始化數(shù)據(jù)庫連接池;

第三,如果一個(gè)數(shù)據(jù)庫操作管道已經(jīng)被占用,那么其他請求是否應(yīng)該得到這個(gè)管道,也就是說我們要考慮多線程并發(fā)下,管道的分配問題;

第四,如果做到管道的復(fù)用?放回池子中,標(biāo)示可用,并不是真正的關(guān)閉管道;

理解數(shù)據(jù)庫連接池底層原理之手寫實(shí)現(xiàn)

IMyPool是一個(gè)接口,對外提供數(shù)據(jù)庫連接池的基本服務(wù),比如得到一個(gè)數(shù)據(jù)庫操作管道。

MyDefaultPool是IMyPool的實(shí)現(xiàn)。

MyPooledConnection代表數(shù)據(jù)庫操作管道,它可以執(zhí)行SQL,關(guān)閉管道等。

MyPoolFactory是一個(gè)工廠,單例模式,用于得到IMyPool實(shí)現(xiàn)。

DBConfigXML代表外部配置文件。

Test用于測試。

DBConfigXML
理解數(shù)據(jù)庫連接池底層原理之手寫實(shí)現(xiàn)
我們在實(shí)際中使用數(shù)據(jù)庫連接池,需要在Spring的配置文件中,進(jìn)行一些參數(shù)配置。這里,為了簡化解析,直接提供。
MyPooledConnection理解數(shù)據(jù)庫連接池底層原理之手寫實(shí)現(xiàn)
所謂數(shù)據(jù)庫連接管道,就是對JDBC Connection進(jìn)行封裝而已,但是需要注意isBusy的這個(gè)標(biāo)示。對管道的關(guān)閉,實(shí)際上只是標(biāo)示的改變而已!
IMyPool
理解數(shù)據(jù)庫連接池底層原理之手寫實(shí)現(xiàn)
MyDefaultPool
理解數(shù)據(jù)庫連接池底層原理之手寫實(shí)現(xiàn)
需要注意到是,MyDefaultPool持有一個(gè)管道集合,基于多線程的考慮,這里使用了Vector。
MyDefaultPool需要初始化
理解數(shù)據(jù)庫連接池底層原理之手寫實(shí)現(xiàn)
數(shù)據(jù)庫連接池需要根據(jù)外部配置文件完成數(shù)據(jù)庫驅(qū)動(dòng)加載以及初始化管道的建立
createMyPooledConnection接口實(shí)現(xiàn)
理解數(shù)據(jù)庫連接池底層原理之手寫實(shí)現(xiàn)

數(shù)據(jù)庫連接池在創(chuàng)建管道時(shí),應(yīng)該去看一下是否達(dá)到上限,如果沒有,則可以創(chuàng)建。

不僅僅要?jiǎng)?chuàng)建出來,還要標(biāo)示每一個(gè)管道的isBusy標(biāo)志。

getMyPooledConnection接口實(shí)現(xiàn)
理解數(shù)據(jù)庫連接池底層原理之手寫實(shí)現(xiàn)
這里需要注意的是:如果得不到操作管道,需要去創(chuàng)建管道!
getRealConnectionFromPool
理解數(shù)據(jù)庫連接池底層原理之手寫實(shí)現(xiàn)

第一,這里使用了synchronized,就是為了避免多線程下產(chǎn)生問題。

第二,要知道Connection是有超時(shí)機(jī)制的,如果我們得到的管道的Connection已經(jīng)超時(shí)了怎么辦呢?

第三,得到管道后,一定注意isBusy的設(shè)置。

MyPoolFactory
理解數(shù)據(jù)庫連接池底層原理之手寫實(shí)現(xiàn)
Test測試
理解數(shù)據(jù)庫連接池底層原理之手寫實(shí)現(xiàn)
運(yùn)行結(jié)果
理解數(shù)據(jù)庫連接池底層原理之手寫實(shí)現(xiàn)


網(wǎng)站標(biāo)題:理解數(shù)據(jù)庫連接池底層原理之手寫實(shí)現(xiàn)
標(biāo)題路徑:http://weahome.cn/article/pjojjj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部