c3p0池不起作用(使用hibernate和数据源,在tomcat上)

时间:2013-04-04 11:56:32

标签: java hibernate tomcat c3p0 pooling

我们有一个在tomcat 6上运行的java web应用程序,它正在调用jar来持久化。此jar位于tomcat lib文件夹中,并使用tomcat数据源:

<Resource name="jdbc/mydatasource"
          auth="Container"
          type="javax.sql.DataSource"
          username="USER"
          password="PASSWORD"
          driverClassName="org.postgresql.Driver"
          url="jdbc:postgresql://HOST:5432/DATABASE"/>

jar是java项目的二进制文件,它使用hibernate 3.5.6-Final for ORM。 hibernate配置如下:

    <property name="hibernate.c3p0.min_size">5</property>
    <property name="hibernate.c3p0.max_size">20</property>
    <property name="hibernate.c3p0.timeout">1800</property>
    <property name="hibernate.c3p0.max_statements">50</property>
    <property name="hibernate.connection.datasource">java:jdbc/mydatasource</property> 
    <property name="dialect">org.hibernate.dialect.PostgreSQLDialect</property> 

首先,我们没有在应用程序中包含hibernate-c3p0软件包,因此未使用c3p0设置。整个应用程序都可以这样工作。

我们添加了hibernate-c3p0包,以便实现更好的池管理。所以这个包现在已经嵌入jar中以保持持久性。

但我们现在有了这个错误(它出现在每次启动后,当weba应用程序试图从persistance jar中检索数据时):

  

[Task-Thread-for-com.mchange.v2.async.ThreadPerTaskAsynchronousRunner@eafa5f] 13   :46:22 WARN - BasicResourcePool $ AcquireTask :()com.mchange.v2.resourcepool.Basi   cResourcePool $ AcquireTask @ b321c1 - 获取尝试失败!!!清除pendi   ng获得。在尝试获取所需的新资源时,我们未能成功    超过允许的最大获取尝试次数(30)。最后的acquisi   尝试例外:   显示java.lang.NullPointerException           at sun.jdbc.odbc.JdbcOdbcDriver.getProtocol(JdbcOdbcDriver.java:507)           at sun.jdbc.odbc.JdbcOdbcDriver.knownURL(JdbcOdbcDriver.java:476)           at sun.jdbc.odbc.JdbcOdbcDriver.acceptsURL(JdbcOdbcDriver.java:307)           at java.sql.DriverManager.getDriver(DriverManager.java:253)           在com.mchange.v2.c3p0.DriverManagerDataSource.driver(DriverManagerDataS   ource.java:224)           在com.mchange.v2.c3p0.DriverManagerDataSource.getConnection(DriverManag   erDataSource.java:120)           在com.mchange.v2.c3p0.WrapperConnectionPoolDataSource.getPooledConnecti   上(WrapperConnectionPoolDataSource.java:143)           在com.mchange.v2.c3p0.WrapperConnectionPoolDataSource.getPooledConnecti   上(WrapperConnectionPoolDataSource.java:132)           在com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool $ 1PooledConnectionRe   sourcePoolManager.acquireResource(C3P0PooledConnectionPool.java:137)           在com.mchange.v2.resourcepool.BasicResourcePool.doAcquire(BasicResource)   Pool.java:1014)           在com.mchange.v2.resourcepool.BasicResourcePool.access $ 800(BasicResourc   ePool.java:32)           在com.mchange.v2.resourcepool.BasicResourcePool $ AcquireTask.run(BasicRe)   sourcePool.java:1810)           at com.mchange.v2.async.ThreadPerTaskAsynchronousRunner $ TaskThread.run(T   hreadPerTaskAsynchronousRunner.java:255)

这似乎是错误的,因为似乎使用了Ojdbc驱动程序而不是数据源中定义的postgresql驱动程序。

你知道什么可以使这个错误出现,以及如何解决它?

我在hibernate配置中尝试了不同的东西,我在stackoverflow和不同的论坛中找到了,这些都没有解决问题:

<property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>

    <property name="hibernate.connection.driver_class">org.postgresql.Driver</property>
    <property name="driverClass">org.postgresql.Driver</property>
    <property name="hibernate.c3p0.driverClass">org.postgresql.Driver</property>

我必须确切地说,我们只能控制用于持久性和tomcat安装的jar。我们无法修改调用jar的Web应用程序。

1 个答案:

答案 0 :(得分:1)

也许你的应用程序根本不是要使用Tomcat配置的数据源,只是通过hibernate工作?您是否尝试过跳过Resource XML(这对于c3p0 DataSource来说不太合适),只是为c3p0配置hibernate?

<!-- add these -->
<property name="hibernate.connection.driver_class">org.postgresql.Driver</property>
<property name="hibernate.connection.url">jdbc:postgresql://HOST:5432/DATABASE</property>
<property name="hibernate.connection.username">USER</property>
<property name="hibernate.connection.password">PASSWORD</property>

<!-- same as before -->
<property name="hibernate.c3p0.min_size">5</property>
<property name="hibernate.c3p0.max_size">20</property>
<property name="hibernate.c3p0.timeout">1800</property>
<property name="hibernate.c3p0.max_statements">50</property>
<property name="dialect">org.hibernate.dialect.PostgreSQLDialect</property> 

<!-- REMOVE THIS! -->
<!-- <property name="hibernate.connection.datasource">java:jdbc/mydatasource</property> -->