資料庫連接配接池的基本思想是:為資料庫連接配接建立一個“緩沖池”,預先在池中放入一定數量的資料庫連接配接管道,需要時,從池子中取出管道進行使用,操作完畢後,在将管道放入池子中,進而避免了頻繁的向資料庫申請資源,釋放資源帶來的性能損耗。在如今的分布式系統當中,系統的QPS瓶頸往往就在資料庫,是以了解資料庫連接配接池底層構造原理與設計思想是很有益處的。我們常用的資料庫連接配接池有C3P0,DBCP,Druid等,下面我們就來分析下資料庫連接配接池應該有些什麼,以及手寫一個迷你版的資料庫連接配接池!

第一,資料庫連接配接池中存放的就是資料庫操作管道,不僅僅是存放,而且應該是管理這些管道; 第二,應該提供外部配置檔案去初始化資料庫連接配接池; 第三,如果一個資料庫操作管道已經被占用,那麼其他請求是否應該得到這個管道,也就是說我們要考慮多線程并發下,管道的配置設定問題; 第四,如果做到管道的複用?放回池子中,标示可用,并不是真正的關閉管道;
IMyPool是一個接口,對外提供資料庫連接配接池的基本服務,比如得到一個資料庫操作管道。 MyDefaultPool是IMyPool的實作。 MyPooledConnection代表資料庫操作管道,它可以執行SQL,關閉管道等。 MyPoolFactory是一個工廠,單例模式,用于得到IMyPool實作。 DBConfigXML代表外部配置檔案。 Test用于測試。
我們在實際中使用資料庫連接配接池,需要在Spring的配置檔案中,進行一些參數配置。這裡,為了簡化解析,直接提供。
所謂資料庫連接配接管道,就是對JDBC Connection進行封裝而已,但是需要注意isBusy的這個标示。對管道的關閉,實際上隻是标示的改變而已!
需要注意到是,MyDefaultPool持有一個管道集合,基于多線程的考慮,這裡使用了Vector。
資料庫連接配接池需要根據外部配置檔案完成資料庫驅動加載以及初始化管道的建立。
資料庫連接配接池在建立管道時,應該去看一下是否達到上限,如果沒有,則可以建立。 不僅僅要建立出來,還要标示每一個管道的isBusy标志。
這裡需要注意的是:如果得不到操作管道,需要去建立管道!
第一,這裡使用了synchronized,就是為了避免多線程下産生問題。 第二,要知道Connection是有逾時機制的,如果我們得到的管道的Connection已經逾時了怎麼辦呢? 第三,得到管道後,一定注意isBusy的設定。
本文轉自zfz_linux_boy 51CTO部落格,原文連結:http://blog.51cto.com/zhangfengzhe/2069971,如需轉載請自行聯系原作者