15

MySQLの接続は8時間タイムアウトしているようです。HibernateforORMを利用してTomcatで複数のWARを実行しています。8時間後(つまり一晩)、アイドル状態の接続を取得するとパイプが壊れます。

私はすでにコードをトレースし、すべてのトランザクションをコミットまたはロールバックすることを二重に確認しました。

これが私のhibernate.cfg.xmlです

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
    <property name="hibernate.bytecode.use_reflection_optimizer">false</property>
    <property name="hibernate.connection.driver_class">org.gjt.mm.mysql.Driver</property>
    <property name="hibernate.connection.password"></property>
    <property name="hibernate.connection.url">jdbc:mysql://localhost/test</property>
    <property name="hibernate.connection.username">root</property>
    <property name="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
    <property name="hibernate.transaction.factory_class">org.hibernate.transaction.JDBCTransactionFactory</property>
    <property name="hibernate.current_session_context_class">thread</property>
    <!--property name="hibernate.show_sql">true</property>
    <property name="hibernate.format_sql">true</property-->

    <property name="c3p0.min_size">3</property>
    <property name="c3p0.max_size">5</property>
    <property name="c3p0.timeout">1800</property>
    <property name="c3p0.preferredTestQuery">SELECT 1</property>
    <property name="c3p0.testConnectionOnCheckout">true</property>
    <property name="c3p0.idle_test_period">100</property> <!-- seconds -->

    <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>
    <property name="cache.use_query_cache">false</property>
    <property name="cache.use_minimal_puts">false</property>
    <property name="max_fetch_depth">10</property>

    <property name="hibernate.hbm2ddl.auto">update</property>

    <!-- classes removed -->

</session-factory>

私が修正したと思ったパラメータはc3p0.idle_test_period--です。デフォルトは0です。ただし、8時間実行した後も、パイプの破損の問題が発生します。Google経由で複数の投稿インデックスがありますが、満足のいく答えに到達するものはありません。

4

5 に答える 5

25

そのため、c3p0 を有効にするキー行が欠落していたことがわかりました (Hibernate が組み込みの接続プールを使用していたため、微調整していた c3p0 パラメーターは効果がありませんでした。これは、運用には適していないと適切に警告しています)。hibernate 2.x では、hibernate.c3p0.max_sizeプロパティを設定すると c3p0 接続プールが有効になりました。ただし、3.x では次のプロパティを指定する必要があります --

<property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>

さらに、ここに私の最終的な設定パラメータがあります -

<property name="hibernate.c3p0.min_size">3</property>
<property name="hibernate.c3p0.max_size">5</property>
<property name="hibernate.c3p0.timeout">1800</property>
<property name="hibernate.c3p0.idle_test_period">100</property> <!-- seconds -->

この点に関して、Hibernate と c3p0 の両方にひどいドキュメントがあるのはかなり残念です。

于 2009-04-10T16:09:09.227 に答える
2

これは、c3p0 で tomcat の wait_timeout=28800 sec(8h) と maxIdleTime=0 の組み合わせが原因でパイプが壊れている場合の解決策です。

my.ini ファイルでローカルの tomcat の wait_timeout を 120 秒 (2 分) に変更しました。そして、以下を配置しました:
maxIdleTime=100
idleConnectionTestPeriod=0 (デフォルトと同じ/存在しないかのように)
その他:
acquireIncrement=2
minPoolSize=2
maxPoolSize=5
maxIdleTimeExcessConnections=10

この設定で問題はありませんでした。

idleConnectionTestPeriod を使用する必要はありませんでした。

tomcat の wait_timeout が 28800 秒で、maxIdleTime が 25200 秒の場合、c3p0 は 3600 秒 (1 時間) 早く、Tomcat が「壊れたパイプ」例外をスローする前に、アイドル状態の接続を閉じることを意味します。そうじゃないですか!

ご覧のとおり、maxIdleTime のみを提供しても問題はありません。


残念
ながら、次のようなものがあり
ます

ところで、Tomcat の my.ini ファイルを Notepad++ で開く方法は次のとおりです: http://drupal.org/node/32715#comment-4907440

乾杯、
デスポット

于 2012-09-18T15:05:27.507 に答える
2

ここでは 2 つのことが行われています。詳細については、この記事を読む必要がありますが、要点は次のとおりです。

  1. 必要に応じて、MySQL のwait_timeout設定を 8 時間以上に調整できます。
  2. 休止状態の設定には「休止状態」が含まれている必要があります。「c3p0」の前、例えばhibernate.c3p0.idle_test_period、ただの代わりにc3p0.idle_test_period
于 2009-04-08T21:39:24.497 に答える
1

私はいくつかの問題を抱えています - - C3P0ConnectionProvider が見つかりませんでした - 休止状態の c3p0 バージョンを使用して解決します

        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-entitymanager</artifactId>
        <version>3.5.6-Final</version>
    </dependency>
          <!-- c3p0 -->
    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-c3p0</artifactId>
        <version>3.3.1.GA</version>
    </dependency>

- mysql で wait_timeout の問題があります。最初に /etc/my.cnf wait_timeout=10 を設定し、次に Idle タイムアウト値を < 10 の wait_timeout 値よりも低く変更して、問題を解決しました。

    <property name="hibernate.connection.provider_class" value="org.hibernate.connection.C3P0ConnectionProvider" /> <property name="hibernate.c3p0.acquire_increment" value="1" />
        <property name="hibernate.c3p0.idle_test_period"  value="28690"/>
        <property name="hibernate.c3p0.timeout" value="1800" />
        <property name="hibernate.c3p0.max_size" value="5" />
        <property name="hibernate.c3p0.min_size" value="3" />
        <property name="hibernate.c3p0.max_statement" value="50" />
        <property name="hibernate.c3p0.preferredTestQuery" value="select 1;"/>
于 2012-04-20T16:58:48.093 に答える
1

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

私は 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-12T10:24:48.047 に答える