c3p0是什么
c3p0的出現,是為了大大提高應用程序和數據庫之間訪問效率的。
它的特性:
- 編碼的簡單易用
- 連接的復用
- 連接的管理
說到c3p0,不得不說一下jdbc本身,c3p0愿意就是對數據庫連接的管理,那么原有的概念還是得清晰:DriverManager、Connection、StateMent、ResultMent。
jdbc:java database connective這套API,不用多說,是一套用于連接各式dbms或連接橋接器的api,兩個層級:上層供應用方調用api,下層,定義了各個dbms的spi的api(具體文檔見:這里)。
主要要提的是:datasource、DriverManager,想到哪兒寫到哪兒,datasource是更高級一點的api,原因在于相對對應用來說更透明。
Connection:同dbms的邏輯鏈接,類似于session管理概念, SQL statements are executed and results are returned within the context of a connection.
jdbc的概念就到這里,平時用得比較多。
c3P0的配置
c3p0的bean配置如下:
1
2
3
4
5
6
7
8
9
10
|
< bean id = "dataSource" class = "com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method = "close" > < property name = "driverClass" value = "${jdbc.driverClassName}" /> < property name = "jdbcUrl" value = "${jdbc.url}" /> < property name = "user" value = "${jdbc.username}" /> < property name = "password" value = "${jdbc.password}" /> < property name = "checkoutTimeout" value = "30000" /> < property name = "maxPoolSize" value = "15" /> < property name = "idleConnectionTestPeriod" value = "180" /> < property name = "maxIdleTime" value = "180" /> </ bean > |
還有一些配置選項,后續詳細說明。可見c3p0的bean引用使用的是:ComboPooledDataSource,該類結構如下:
以上類圖都不是很完全,不過大體能表達出類之間的原理:
1、bean:ComboPooledDataSource的父類:AbstractPoolBackedDataSource有一個poolmanager字段,存儲著對pool管理器
2、獲取ds.getConnection()鏈接對象時,內部使用getPoolManger()獲取C3p0ConnectionPooledManager(mgr)對象,該manager管理著pool對象:C3P0PooledConnectionPool對象,mgr.getPool().checkoutPooledConnection()
3、自此該connection已經被獲取到了
4、讓我們看看該connection的真實面目吧:
ProxyConnection。
5、因此其實原理是:
從pool里獲取到的connection,是proxy包裝的connection,而對connection的釋放或者重用,是pool的管理責任:初始化池大小,維護池的大小(expand或shrink),管理unused、expired、checkout、checkin連接。
真正底層的連接是jdbc自己的連接,而c3p0的管理部分,基本上使用的是synchronized關鍵字,使用timerTask定時器工作。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。