溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

理解數據庫連接池底層原理之手寫實現

發布時間:2020-05-24 18:59:54 來源:網絡 閱讀:594 作者:江彩 欄目:編程語言

理解數據庫連接池底層原理之手寫實現

第一,數據庫連接池中存放的就是數據庫操作管道,不僅僅是存放,而且應該是管理這些管道;

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

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

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

理解數據庫連接池底層原理之手寫實現

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

MyDefaultPool是IMyPool的實現。

MyPooledConnection代表數據庫操作管道,它可以執行SQL,關閉管道等。

MyPoolFactory是一個工廠,單例模式,用于得到IMyPool實現。

DBConfigXML代表外部配置文件。

Test用于測試。

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

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

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

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

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

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

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

MyPoolFactory
理解數據庫連接池底層原理之手寫實現
Test測試
理解數據庫連接池底層原理之手寫實現
運行結果
理解數據庫連接池底層原理之手寫實現

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女