Hi All:
上周我们网站大部分任务的C3P0配置出现错误,我对于C3P0以前也了解不多,趁机学习了一下。
C3P0
数据库连接池
没有连接池的数据库连接方式是直接通过DriverManager和DataSource进行连接,因为相关连接的建立以及关闭是非常耗时的.如果使用连接池,将有池来管理相关的数据库连接,减少对数据库连接操作.
阻塞机制
c3p0和大多数pool一样是基于阻塞(blocked)机制来管理数据库连接池的,当池里面没有可用的connection会被阻塞,一般是通过wait(),当池里面的connection有了可用的connection,会通过notify()唤醒。
使用 c3p0
有三种方式可以使用c3p0:
1.直接初始化和配置ComboPooledDataSource Bean
2.使用 DataSources Factory
3.通过 PoolBackedDataSource 并设置 ConectionPoolDataSource来创建你自己的
最常用的是第一种。无论以什么方式获得了DataSource,c3p0都可以提供一个名为 c3p0.properties 的文件来配置该数据源,从c3p0-0.9.1开始,还可以通过文件c3p0-config.xml来进行高级配置。如果为提供任何配置文件数据源仍然可以使用缺省配置来工作。
所有的配置项:
想了解这些配置项的具体含义可以参考官方文档:http://www.mchange.com/projects/c3p0/index.html
Quick start
ComboPooledDataSource cpd = new ComboPooledDataSource();
cpd.setDriverClass("com.alibaba.china.jdbc.SimpleDriver");
cpd.setJdbcUrl("jdbc:oracle:thin:@10.20.36.18:1521:ocndb");
cpd.setUser("alibaba");
cpd.setPassword("ca");
cpd.setProperties(crateProperties());
c3p0的API还是非常简单的,Properties里面有一些可选信息可以配置。在实际应用中一般托管给spring管理,详见晓军回复的邮件里面的配置。
C3p0 JMX监控
C3p0自带了jmx监控,可以很方便的通过jconsole查看运行时的信息,可惜我研究了半天也无法按照文档上描述的那样成功看到C3P0监控信息。晚上回家再研究一下,可能是我们公司使用的C3P0的版本问题。(如果有谁知道也可以回复一下J)
参考:
http://hzh0725.iteye.com/blog/396004
http://sourceforge.net/projects/c3p0/
http://yalong9527.iteye.com/blog/457571
官方文档:http://www.mchange.com/projects/c3p0/index.html