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

标签 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 应用程序试图从持久性 jar 中检索数据时):

[Task-Thread-for-com.mchange.v2.async.ThreadPerTaskAsynchronousRunner@eafa5f] 13 :46:22 WARN - BasicResourcePool$AcquireTask: () com.mchange.v2.resourcepool.Basi cResourcePool$AcquireTask@b321c1 -- Acquisition Attempt Failed!!! Clearing pendi ng acquires. While trying to acquire a needed new resource, we failed to succeed more than the maximum number of allowed acquisition attempts (30). Last acquisi tion attempt exception: 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) at com.mchange.v2.c3p0.DriverManagerDataSource.driver(DriverManagerDataS ource.java:224) at com.mchange.v2.c3p0.DriverManagerDataSource.getConnection(DriverManag erDataSource.java:120) at com.mchange.v2.c3p0.WrapperConnectionPoolDataSource.getPooledConnecti on(WrapperConnectionPoolDataSource.java:143) at com.mchange.v2.c3p0.WrapperConnectionPoolDataSource.getPooledConnecti on(WrapperConnectionPoolDataSource.java:132) at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool$1PooledConnectionRe sourcePoolManager.acquireResource(C3P0PooledConnectionPool.java:137) at com.mchange.v2.resourcepool.BasicResourcePool.doAcquire(BasicResource Pool.java:1014) at com.mchange.v2.resourcepool.BasicResourcePool.access$800(BasicResourc ePool.java:32) at 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>

我必须明确一点,我们只能控制用于持久化的 jar 和 tomcat 安装。我们无法修改调用 jar 的 Web 应用程序。

最佳答案

也许您的应用程序根本不会转到 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> --> 

关于java - c3p0 池不起作用(在 tomcat 上使用 hibernate 和数据源),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15810416/

相关文章:

Java:如何写入webapp中的文件夹?

java - 在 Servlet 的 destroy() 方法中调用 System.exit()

tomcat - 支持tomcat上的多语言网站

java - 缺少 Maven Shade JavaFX 运行时组件

java - EHCache 好像不起作用

java - Hibernate 条件返回包含列值的列表

java - Hibernate 3.5.1、JPA2.0 和 MySQL - 2 个差异数据库/同一服务器内的替代行为

java - webXml 不工作

java - Java中随便引用方法时的命名约定

java - 在java中加载特定的类文件