MySQL的連接似乎有8小時超時。我在Tomcat中使用Hibernate for ORM運行多個WAR。 8小時後(即過夜),當我拿起空閒的連接時,我會斷開管道。Hibernate,C3P0,Mysql - Broken Pipe
我已經通過代碼追蹤了兩次,並確認我提交或回滾所有事務。
這裏是我的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有多個帖子索引,但沒有一個能得到滿意的答案。
謝謝,這對我有幫助。我同意文檔評論。更糟糕的是,c3p0文檔建議您將c3p0.properties用於除上述5之外的其他所有其他用戶,但這不起作用。只有當你在沒有hibernate前綴的情況下在persistence.xml中指定時纔有效(如你在原始cfg.xml中所做的那樣) – Sun 2010-07-16 15:58:46