Hibernate,C3P0、Mysql切れ目のないパイプ
質問
MySQLているようで8時間の間に接続します。私は複数動作における戦争Tomcatを活かし、HibernateのためのORM.後8時(一晩)を取得しま壊れたパイプで拾ったは、アイドリング接続します。
しかし、私は追跡を通じて、コードやっていて万全を期しcommitまたはrollbackすべての取引です。
こちらは自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時間ます。がありますが複数のポストindexしますので、満足すべて解答すること。
解決
それは私がC3P0を有効にキー行が欠落していたが判明したので(私はHibernateはそれが接続プールに組み込まれて使用していたので、何の効果も持たないし、微調整されたC3P0パラメータ - それが適切に警告したが、生産には適していません)。休止2.xでは、C3P0接続プールを有効にhibernate.c3p0.max_size
プロパティを設定します。しかし、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の両方が、この点で最悪のドキュメントを持っていることではなく残念だ。
他のヒント
がいます。きを読む この記事 詳しくは、-テク遠かっている:
- を調整することができMySQL wait_timeout 設定にもより8時間の間が望ましい。
- Hibernateの設定は"hibernate."前"c3p0"など
hibernate.c3p0.idle_test_period
のではなくc3p0.idle_test_period
これは解決されます:
私は、ローカルのTomcatは、(2分)を120秒するmy.iniファイルを経由してWAIT_TIMEOUT変更しました。
:そして、私は次のように配置しました
MaxIdleTimeエレメン= 100
idleConnectionTestPeriod = 0(それが存在していなかったかのように、デフォルトの/と同じ)
その他:
acquireIncrement = 2
minPoolSize = 2
maxPoolSize = 5
maxIdleTimeExcessConnections = 10
私はこの設定で問題はなかったです。
私はidleConnectionTestPeriodを使用する必要はありませんでした!
TomcatのWAIT_TIMEOUTが28800秒であり、そしてMaxIdleTimeエレメンが25200である場合、それはTomcatの「壊れたパイプ」例外をスローする前にC3P0は、以前3600sec(1H)アイドル接続をクローズすることを意味します。それは右ではないか!
あなたは、私が提供して何の問題を持っていない見ることができるようにだけMaxIdleTimeエレメンます。
残念ながら、これら:
MaxIdleTimeエレメンの
idleConnectionTestPeriod の
configuring_connection_testing の
testConnectionOnCheckin の
あまりにも多くのコーナーケースを説明していません。
そして、ところで、ここ++メモ帳でTomcatのmy.iniファイルを開く方法です。 http://drupal.org/node/32715#comment-4907440する
乾杯、
専制君主
私はいくつかの問題をしました - - C3P0ConnectionProviderが見つかりませんでした - 私は、Hibernateの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
私は10 <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;"/>
私は同じ問題を得ていたし、それが解決策を見つけ出すのに時間がかかっています。
私は4.0.1とMySQL 5.1(無Springフレームワーク)を休止状態使用して、私は問題に直面していました。まず、あなたが不可欠であり、適切に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で設定されたプロパティを取っていた原因役に立たない」のだ、あなたはそれがログに確認することができます。だから、私は右の解決のために多くのウェブサイトを検索し、最終的に私はこの思い付きました。 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接続を取りますが、我々はhibernate.cfg.xmlでこれらのプロパティを追加する必要はありません原因C3P0接続プール」
<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する
私は、これはあなたの問題を解決を願っています。