MySQL的连接时间似乎有8小时。我在Tomcat中使用Hibernate for ORM运行多个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小时后出现Broken Pipe问题。虽然谷歌有多个帖子索引,但没有一个得到满意的答案。
答案 0 :(得分:23)
所以事实证明我错过了启用c3p0的关键线(我调整的c3p0参数没有效果,因为Hibernate使用它内置的连接池 - 它适当地警告它不适合生产)。在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在这方面都有糟糕的文档。
答案 1 :(得分:2)
这里有两件事。您应该阅读this article了解更多详情,但外卖是:
hibernate.c3p0.idle_test_period
而非c3p0.idle_test_period
答案 2 :(得分:2)
当你因为tomcat的wait_timeout = 28800秒(8h)和c3p0中的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将在3600sec(1h)之前关闭空闲连接,之后tomcat会抛出“断管”异常。不是吗?!
正如您所看到的,我只提供maxIdleTime没有问题。
不幸的是,这些:
maxIdleTime
idleConnectionTestPeriod
configuring_connection_testing
testConnectionOnCheckin
不要过多解释角落的情况。
而且,顺便说一下,这里是如何使用Notepad ++打开tomcat的my.ini文件: http://drupal.org/node/32715#comment-4907440
干杯,
霸
答案 3 :(得分:1)
我有几个问题 - - 未找到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 然后我将空闲超时值更改为低于wait_timeout值&lt; 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 :(得分:1)
我遇到了同样的问题,需要时间来找出解决方案。
我使用Hibernate 4.0.1和mysql 5.1(没有spring框架),我遇到了这个问题。首先确保你正确配置了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>
<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属性并在根路径中创建c3p0-config.xml(以及cfg.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
我希望这能解决你的问题。