网络上搜索hibernate3配置c3p0连接池的文章时,出现的内容基本都是如下叙述:
c3p0连接池的配置非常简单,只需要在hibernate.cfg.xml里增加:
<!-- configuration pool -->
<property name="c3p0.acquire_increment">1</property>
<property name="c3p0.idle_test_period">100</property> <!-- seconds -->
<property name="c3p0.max_size">5</property>
<property name="c3p0.max_statements">0</property>
<property name="c3p0.min_size">2</property>
<property name="c3p0.timeout">90</property> <!-- seconds -->
还需要在CLASS_PATH里加上c3p0-x.x.x.jar文件
这种配置在hibernate3根本不起作用(我在Hibernate3.3.1,3.3.2中试验的),大概是hiberante官方文档中没有更改过来,copy泛滥造成的。
其实真正正确的配置还需要在hibenrate配置文件(hibernate.cfg.xml)中添加连接提供器类的配置:
<property name="connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
原因很简单:在Hibernate3中,默认会使用它自己提供的简单连接池实现类。不修改这个连接提供器的实现类,它还是不知道你已经提供了C3P0这个产品了。
在Hibernate3应用中配置c3p0的正确做法是:先在classpath中添加c3p0-x.x.x.jar包,然后在hibernate配置文件中添加如下完整配置信息:
<property name="connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
<property name="c3p0.acquire_increment">1</property>
<property name="c3p0.idle_test_period">100</property>
<property name="c3p0.max_size">5</property>
<property name="c3p0.max_statements">0</property>
<property name="c3p0.min_size">2</property>
<property name="c3p0.timeout">90</property>
另:Hibernate3.3中默认已经不支持DBCP连接池的配置了(因为DBCP被公认为存在一些BUG,例如当DBCP连接因为某个原因断掉后,不会自动重新连接)。如果想使用DBCP,还得定义一个ConnectionProvider类(实现ConnectionProvider接口)。
最后: 希望初学者不要只信网络文章,而自己不通过实践来验证。