一直用c3p0好久了,但也沒時間或沒主動去研究過,直到最近頻頻在出現一些莫名其妙的問題,以爲仍是有必要了解和研究一下。html
c3p0的出現,是爲了大大提升應用程序和數據庫之間訪問效率的。java
它的特性:數據庫
說到c3p0,不得不說一下jdbc自己,c3p0願意就是對數據庫鏈接的管理,那麼原有的概念仍是得清晰:DriverManager、Connection、StateMent、ResultMent。api
jdbc:java database connective這套API,不用多說,是一套用於鏈接各式dbms或鏈接橋接器的api,兩個層級:上層供應用方調用api,下層,定義了各個dbms的spi的api(具體文檔見:這裏)。session
主要要提的是:datasource、DriverManager,想到哪兒寫到哪兒,datasource是更高級一點的api,緣由在於相對對應用來講更透明。oracle
Connection:同dbms的邏輯連接,相似於session管理概念, SQL statements are executed and results are returned within the context of a connection.編碼
jdbc的概念就到這裏,平時用得比較多。url
c3p0的bean配置以下:spa
1 <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close"> 2 <property name="driverClass" value="${jdbc.driverClassName}" /> 3 <property name="jdbcUrl" value="${jdbc.url}" /> 4 <property name="user" value="${jdbc.username}" /> 5 <property name="password" value="${jdbc.password}" /> 6 <property name="checkoutTimeout" value="30000" /> 7 <property name="maxPoolSize" value="15" /> 8 <property name="idleConnectionTestPeriod" value="180" /> 9 <property name="maxIdleTime" value="180" /> 10 </bean>
還有一些配置選項,後續詳細說明。可見c3p0的bean引用使用的是:ComboPooledDataSource,該類結構以下:3d
以上類圖都不是很徹底,不過大致能表達出類之間的原理:
一、bean:ComboPooledDataSource的父類:AbstractPoolBackedDataSource有一個poolmanager字段,存儲着對pool管理器
二、獲取ds.getConnection()連接對象時,內部使用getPoolManger()獲取C3p0ConnectionPooledManager(mgr)對象,該manager管理着pool對象:C3P0PooledConnectionPool對象,mgr.getPool().checkoutPooledConnection()
三、自此該connection已經被獲取到了
四、讓咱們看看該connection的真實面目吧:
ProxyConnection。
五、所以其實原理是:
從pool裏獲取到的connection,是proxy包裝的connection,而對connection的釋放或者重用,是pool的管理責任:初始化池大小,維護池的大小(expand或shrink),管理unused、expired、checkout、checkin鏈接。
真正底層的鏈接是jdbc本身的鏈接,而c3p0的管理部分,基本上使用的是synchronized關鍵字,使用timerTask定時器工做。