C3P0简介

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来进行高级配置。如果为提供任何配置文件数据源仍然可以使用缺省配置来工作。

所有的配置项:



 

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

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值