我们有一个java web应用程序运行在tomcat 6上,它正在调用一个jar来持久。这个jar位于Tomcat的lib文件夹,并使用Tomcat的数据源:c3p0池不工作(与休眠和数据源,在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"/>
罐子是一个Java项目,它使用Hibernate 3.5.6决赛的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 pplication尝试检索从持久性数据罐子):
[任务多线程换com.mchange.v2。 [email protected]] 13 :46:22 WARN - BasicResourcePool $ AcquireTask:()com.mchange.v2.resourcepool.Basi cResourcePool $ AcquireTask @ b321c1 - 采集尝试失败!!!清除零售店 ng获得。在尝试获取所需的新资源时,我们未能成功执行 以上的最大允许获取次数(30次)。最后习得 重刑尝试例外: 显示java.lang.NullPointerException 在sun.jdbc.odbc.JdbcOdbcDriver.getProtocol(JdbcOdbcDriver.java:507) 在sun.jdbc.odbc.JdbcOdbcDriver.knownURL(JdbcOdbcDriver.java:476) 在sun.jdbc.odbc.JdbcOdbcDriver.acceptsURL(JdbcOdbcDriver.java:307) 在java.sql.DriverManager.getDriver(DriverManager.java:253) 在com.mchange.v2.c3p0.DriverManagerDataSource.driver(DriverManagerDataS 乌尔斯河的.java:224) 在com.mchange.v2.c3p0.DriverManagerDataSource.getConnection(DriverManag erDataSource.java:120) 在上(WrapperCon com.mchange.v2.c3p0.WrapperConnectionPoolDataSource.getPooledConnecti nectionPoolDataSource.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) 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的配置,我在计算器和不同的论坛,不解决问题的发现:
<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应用程序。
您是否添加了c3p0-0.9。*。jar? – mac 2013-08-26 12:24:43