/ / c3p0プーリングが機能していない(Tomcat上のhibernateとデータソースを使用) - java、hibernate、tomcat、c3p0、プーリング

c3p0のプーリングは動作しません(Tomcatのhibernateとデータソースを使用) - java、hibernate、tomcat、c3p0、pooling

永続化のためにjarを呼び出している、Tomcat 6上で実行されているJava Webアプリケーションがあります。この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はORMにhibernate 3.5.6-Finalを使用するJavaプロジェクトのバイナリです。 休止状態の設定は次のとおりです。

    <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に埋め込まれています。

しかし、このエラーが発生しました(各起動後、Webアプリケーションが永続化jarからデータを取得しようとすると表示されます)。

[Task-Thread-for-com.mchange.v2.async。ThreadPerTaskAsynchronousRunner @ eafa5f] 13 :46:22警告 - 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 ource.java:224) com.mchange.v2.c3p0.DriverManagerDataSource.getConnection(DriverManag erDataSource.java:120) com.mchange.v2.c3p0.WrapperConnectionPoolDataSource.getPooledConnectiで on(WrapperConnectionPoolDataSource.java:143) com.mchange.v2.c3p0.WrapperConnectionPoolDataSource.getPooledConnectiで on(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) com.mchange.v2.async.ThreadPerTaskAsynchronousRunner $ TaskThread.run(T) hreadPerTaskAsynchronousRunner.java:255)

データソースで定義されているpostgresqlドライバの代わりにOjdbcドライバが使用されているように見えるため、これは間違っているように見えます。

このエラーが発生する原因、および解決方法をご存知ですか。

私は問題を解決していない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は1

たぶんあなたのアプリはTomcatに行きませんまったく設定されたデータソースは、単に休止状態を通して働いていますか? 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> -->