數據庫鏈接池的基本思想是:爲數據庫鏈接創建一個「緩衝池」,預先在池中放入必定數量的數據庫鏈接管道,須要時,從池子中取出管道進行使用,操做完畢後,在將管道放入池子中,從而避免了頻繁的向數據庫申請資源,釋放資源帶來的性能損耗。在現在的分佈式系統當中,系統的QPS瓶頸每每就在數據庫,因此理解數據庫鏈接池底層構造原理與設計思想是頗有益處的。咱們經常使用的數據庫鏈接池有C3P0,DBCP,Druid等,下面咱們就來分析下數據庫鏈接池應該有些什麼,以及手寫一個迷你版的數據庫鏈接池!數據庫
第一,數據庫鏈接池中存放的就是數據庫操做管道,不單單是存放,並且應該是管理這些管道;多線程
第二,應該提供外部配置文件去初始化數據庫鏈接池;併發
第三,若是一個數據庫操做管道已經被佔用,那麼其餘請求是否應該獲得這個管道,也就是說咱們要考慮多線程併發下,管道的分配問題;分佈式
第四,若是作到管道的複用?放回池子中,標示可用,並非真正的關閉管道;ide
IMyPool是一個接口,對外提供數據庫鏈接池的基本服務,好比獲得一個數據庫操做管道。性能
MyDefaultPool是IMyPool的實現。測試
MyPooledConnection表明數據庫操做管道,它能夠執行SQL,關閉管道等。ui
MyPoolFactory是一個工廠,單例模式,用於獲得IMyPool實現。線程
DBConfigXML表明外部配置文件。設計
Test用於測試。
咱們在實際中使用數據庫鏈接池,須要在Spring的配置文件中,進行一些參數配置。這裏,爲了簡化解析,直接提供。
所謂數據庫鏈接管道,就是對JDBC Connection進行封裝而已,可是須要注意isBusy的這個標示。對管道的關閉,實際上只是標示的改變而已!
須要注意到是,MyDefaultPool持有一個管道集合,基於多線程的考慮,這裏使用了Vector。
數據庫鏈接池須要根據外部配置文件完成數據庫驅動加載以及初始化管道的創建。
數據庫鏈接池在建立管道時,應該去看一下是否達到上限,若是沒有,則能夠建立。
不單單要建立出來,還要標示每個管道的isBusy標誌。
這裏須要注意的是:若是得不到操做管道,須要去建立管道!
第一,這裏使用了synchronized,就是爲了不多線程下產生問題。
第二,要知道Connection是有超時機制的,若是咱們獲得的管道的Connection已經超時了怎麼辦呢?
第三,獲得管道後,必定注意isBusy的設置。
好了,到這裏,一個迷你版的數據庫鏈接池就有模有樣了!