0

spring/hibernate アプリケーションを使用し、c3p0 接続プーリングを構成しています。c3p0 接続プーリングが有効になっています。ログを確認しました。

10 May 2012 14:55:56  INFO AbstractPoolBackedDataSource:462 - Initializing c3p0 pool... com.mchange.v2.c3p0.ComboPooledDataSource 

しかし、問題は、プログラムで構成されたデータソースを取得し、そのプロパティを表示しようとしましたが、構成ファイルに設定したプロパティが設定されていないことです。以下の設定とデバッグされた値を見つけてください。

<prop key="hibernate.connection.pool.size">20</prop>
                <prop key="hibernate.show_sql">true</prop>
                <prop key="hibernate.format_sql">true</prop>
                <prop key="hibernate.use_sql_comments">true</prop>
                <prop key="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</prop>
                <prop key="hibernate.c3p0.min_size">5</prop>
                <prop key="hibernate.c3p0.max_size">20</prop>
                <prop key="hibernate.c3p0.timeout">300</prop>
                <prop key="hibernate.c3p0.max_statements">50</prop>
                <prop key="hibernate.c3p0.idle_test_period">3000</prop>
                <prop key="hibernate.jdbc.batch_size">50</prop>
                <prop key="hibernate.c3p0.preferredTestQuery">SELECT GETDATE()</prop>
                 <prop key="hibernate.c3p0.testConnectionOnCheckout">true</prop>

デバッグされた値:

ここに画像の説明を入力

以下のようにデータソースを取得しています。

    WebApplicationContext context = WebApplicationContextUtils.getRequiredWebApplicationContext(getServletContext());
.......getBean("datasourceId");
..................

プロパティで、優先テストクエリを設定しました。それは画像でもヌルです。

ここに何か欠けていますか?ありがとう!

4

3 に答える 3

0

私はそれを次のように使用します

<bean id="sessionFactory"  class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
    <property name="dataSource" ref="pooledConn"/>
    <property name="hibernateProperties">
       <props>
         <prop key="hibernate.dialect" >${HIBERNATE.DIALECT}</prop>
        <!--  <prop key="hibernate.show_sql">${HIBERNATE.SHOW_SQL}</prop> -->
          <prop key="hibernate.show_sql">true</prop>
         <prop key="hibernate.hbm2ddl.auto">${HIBERNATE.hBM2DDL.AUTO}</prop>   
       </props>
    </property> 

そしてそれは私にとって絶対に完璧に動作します、あなたはより多くの助けのためにあなたの設定を貼り付けてください

于 2012-05-11T10:10:56.297 に答える
0

私は同じ問題を抱えていて、解決策を見つけるのに時間がかかりました。

私は Hibernate 4.0.1 と mysql 5.1 (Spring Framework なし) を使用していますが、この問題に直面していました。最初に、重要な c3p0 jar が適切に構成されていることを確認してください。

これらのプロパティをhibernate.cfg.xmlで使用しました

<property name="hibernate.c3p0.validate">true</property>
<property name="hibernate.connection.provider_class">org.hibernate.service.jdbc.connections.internal.C3P0ConnectionProvider</property>
<property name="hibernate.c3p0.min_size">5</property>
<property name="hibernate.c3p0.max_size">20</property>
<property name="hibernate.c3p0.max_statements">50</property>
<property name="hibernate.c3p0.preferredTestQuery">SELECT 1;</property>
<property name="hibernate.c3p0.testConnectionOnCheckout">true</property>
<property name="hibernate.c3p0.idle_test_period">10</property>
<property name="hibernate.c3p0.acquireRetryAttempts">5</property>
<property name="hibernate.c3p0.acquireRetryDelay">200</property>
<property name="hibernate.c3p0.timeout">40</property>

しかし、C3p0 は、私が hibernate.cfg.xml で設定したプロパティではなく、デフォルトのプロパティを取得していたため、役に立ちません。ログで確認できます。そこで、適切な解決策を求めて多くの Web サイトを検索し、最終的にこれにたどり着きました。cfg.xml の C3p0 プロパティを削除し、ルート パスに (cfg.xml とともに) c3p0-config.xml を作成し、次のようにプロパティを設定します。

<c3p0-config>
<default-config> 
<property name="automaticTestTable">con_test</property>
<property name="checkoutTimeout">40</property> 
<property name="idleConnectionTestPeriod">10</property> 
<property name="initialPoolSize">10</property>
<property name="maxPoolSize">20</property> 
<property name="minPoolSize">5</property> 
<property name="maxStatements">50</property>
<property name="preferredTestQuery">SELECT 1;</property>
<property name="acquireRetryAttempts">5</property>
<property name="acquireRetryDelay">200</property>
<property name="maxIdleTime">30</property>
</default-config>
</c3p0-config>

ただし、実行すると、ORM は jdbc 接続を取得しますが、C3p0 接続プールは取得しません。これらのプロパティを hibernate.cfg.xml に追加する必要があるためです。

<property name="hibernate.c3p0.validate">true</property>

<property name="hibernate.connection.provider_class">org.hibernate.service.jdbc.connections.internal.C3P0ConnectionProvider</property>

今ではすべてが正常に機能し(少なくとも私にとっては正常に機能しました)、問題は解決しました。

以下を参照して確認してください。

http://www.mchange.com/projects/c3p0/index.html#configuring_connection_testing

https://community.jboss.org/wiki/HowToConfigureTheC3P0ConnectionPool

これで問題が解決することを願っています。

于 2013-06-12T09:45:48.777 に答える
0

構成ファイルに次を追加してみてください。

<prop key="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</prop>
于 2012-05-11T13:07:41.080 に答える