Hi All:

    上周我们网站大部分任务的C3P0配置出现错误,我对于C3P0以前也了解不多,趁机学习了一下。

C3P0

 

数据库连接池

没有连接池的数据库连接方式是直接通过DriverManagerDataSource进行连接,因为相关连接的建立以及关闭是非常耗时的.如果使用连接池,将有池来管理相关的数据库连接,减少对数据库连接操作.

阻塞机制

c3p0和大多数pool一样是基于阻塞(blocked)机制来管理数据库连接池的,当池里面没有可用的connection会被阻塞,一般是通过wait(),当池里面的connection有了可用的connection,会通过notify()唤醒。

 

使用 c3p0

有三种方式可以使用c3p0:

1.直接初始化和配置ComboPooledDataSource Bean

2.使用 DataSources Factory

3.通过 PoolBackedDataSource 并设置 ConectionPoolDataSource来创建你自己的

 

最常用的是第一种。无论以什么方式获得了DataSourcec3p0都可以提供一个名为 c3p0.properties 的文件来配置该数据源,从c3p0-0.9.1开始,还可以通过文件c3p0-config.xml来进行高级配置。如果为提供任何配置文件数据源仍然可以使用缺省配置来工作。

所有的配置项:


C3P0简介
 

想了解这些配置项的具体含义可以参考官方文档: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());

      

 

c3p0API还是非常简单的,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

 

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-06-08
  • 2021-09-01
  • 2022-03-02
猜你喜欢
  • 2021-10-06
  • 2021-10-31
  • 2021-11-29
  • 2021-05-23
  • 2021-06-12
  • 2022-12-23
  • 2021-09-20
相关资源
相似解决方案