我们有一个在 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。休眠配置如下:
<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 -- 采集尝试失败的!!!清算未决收购。在尝试获取所需的新资源时,我们未能成功超过允许的最大获取尝试次数 (30)。上次采集尝试异常:sun.jdbc.odbc.JdbcOdbcDriver.knownURL(JdbcOdbcDriver.java:476) 处 sun.jdbc.odbc.JdbcOdbcDriver.getProtocol(JdbcOdbcDriver.java:507) 处的 java.lang.NullPointerException。 odbc.JdbcOdbcDriver.acceptsURL(JdbcOdbcDriver.java:307) 在 java.sql.DriverManager.getDriver(DriverManager.java:253) 在 com.mchange.v2.c3p0.DriverManagerDataSource。
这似乎是错误的,因为似乎使用的是 Ojdbc 驱动程序而不是数据源中定义的 postgresql 驱动程序。
你知道什么会导致这个错误出现,以及如何解决它?
我在休眠配置中尝试了不同的东西,我在 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 应用程序。