成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

理解數(shù)據(jù)庫連接池底層原理之手寫實現(xiàn)-創(chuàng)新互聯(lián)

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

創(chuàng)新互聯(lián)建站專注于承德企業(yè)網(wǎng)站建設,自適應網(wǎng)站建設,商城網(wǎng)站制作。承德網(wǎng)站建設公司,為承德等地區(qū)提供建站服務。全流程按需求定制制作,專業(yè)設計,全程項目跟蹤,創(chuàng)新互聯(lián)建站專業(yè)和態(tài)度為您提供的服務
第一,數(shù)據(jù)庫連接池中存放的就是數(shù)據(jù)庫操作管道,不僅僅是存放,而且應該是管理這些管道;

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

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

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

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

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

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

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

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

DBConfigXML代表外部配置文件。

Test用于測試。

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

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

不僅僅要創(chuàng)建出來,還要標示每一個管道的isBusy標志。

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

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

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

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

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

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

名稱欄目:理解數(shù)據(jù)庫連接池底層原理之手寫實現(xiàn)-創(chuàng)新互聯(lián)
轉(zhuǎn)載來源:http://jinyejixie.com/article6/jgoog.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供自適應網(wǎng)站、關(guān)鍵詞優(yōu)化網(wǎng)站建設、App開發(fā)、外貿(mào)建站、軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設
绍兴县| 堆龙德庆县| 岢岚县| 盖州市| 积石山| 扶沟县| 连平县| 澄城县| 昌江| 平远县| 博乐市| 宜兰县| 门头沟区| 阜宁县| 庐江县| 凤城市| 包头市| 满洲里市| 天台县| 门头沟区| 广南县| 内黄县| 大连市| 华亭县| 青海省| 沅江市| 郎溪县| 堆龙德庆县| 庆阳市| 京山县| 通渭县| 奉贤区| 西平县| 苍山县| 普宁市| 工布江达县| 福清市| 诸城市| 莱芜市| 鄱阳县| 东源县|