MySQL似乎在其连接上有8个小时的超时。我正在使用Hibernate for ORM在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发布的帖子索引,但没有一个能够令人满意的答案。
c3p0.idle_test_period
因此,事实证明我错过了启用c3p0的关键行(我正在调整的c3p0参数没有任何作用,因为Hibernate使用的是内置连接池- 它会适当警告它不适合生产)。在hibernate 2.x中,设置hibernate.c3p0.max_size属性将启用c3p0连接池。但是,在3.x中,您必须指定以下属性-
hibernate.c3p0.max_size
<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在这方面都有糟糕的文档。