2013-04-04 91 views
2

我們有一個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應用程序。

+0

您是否添加了c3p0-0.9。*。jar? – mac 2013-08-26 12:24:43

回答

1

也許你的應用程序根本就沒有進入Tomcat配置的數據源,只是通過休眠來工作?你有沒有嘗試過跳過資源XML(這對c3p0 DataSource來說不太正確),而只是爲c3p0配置休眠?

<!-- 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> --> 
+0

但是,我想要使用數據源,以便能夠在多個環境中部署相同的二進制文件。用c3p0還可以嗎? – OutOfBound 2013-04-11 11:16:18

+0

爲什麼不呢?如果配置將相同,則可以重新使用未修改。如果沒有,您需要爲每個配置適當地重新配置。 – 2013-04-11 15:00:35

+0

Nah - 我更喜歡連接細節在server.xml中指定。然後我可以隨處部署一次。 – ndtreviv 2014-11-21 13:50:00