Hibernate, C3P0, сломанная труба Mysql

MySQL, кажется, имеет 8-часовой тайм-аут для своих подключений. Я запускаю несколько WAR в Tomcat, используя Hibernate для ORM. Через 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>

The parameter I thought would have fixed it was the c3p0.idle_test_period -- It defaults to 0. However, we still have the Broken Pipe issue after 8 hours of running. While there are multiple posts index via Google, none arrive at a satisfactory answer.


person Mark    schedule 08.04.2009    source источник


Ответы (5)


Итак, оказалось, что мне не хватало ключевой строки, которая включала 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 имеют ужасную документацию по этому поводу.

person Mark    schedule 10.04.2009
comment
Спасибо, мне это помогло. Я согласен с комментарием к документации. Хуже того, документация c3p0 советует вам использовать c3p0.properties для всех остальных, кроме указанных выше 5, но это не работает. Он работает только тогда, когда вы указываете в файле persistence.xml без префикса гибернации (как вы это делали в исходном cfg.xml) - person Sun; 16.07.2010
comment
Мне это тоже помогло ... Насчет документации я согласен :). В их документации было бы немного проще. - person Polaris878; 03.08.2010
comment
Если вы использовали конфигурацию xml для CombPooledDataSource, вам необходимо иметь свойство idleConnectionTestPeriod. - person Joseph Lust; 07.03.2013

Здесь происходят две вещи. Вам следует прочитать эту статью для получения дополнительных сведений. , но выводы следующие:

  1. Вы можете настроить wait_timeout для MySQL. при желании установите значение более 8 часов.
  2. Настройки гибернации должны включать «спящий режим». перед "c3p0", например hibernate.c3p0.idle_test_period вместо просто c3p0.idle_test_period
person Matt Solnit    schedule 08.04.2009
comment
Попробую сегодня добавить префикс гибернации. Я не думаю, что расширение MySQL wait_timeout поможет ... Я бы просто отложил ошибку сломанной трубы. - person Mark; 10.04.2009

Это решение, когда у вас сломан канал из-за комбинации tomcat wait_timeout = 28800 sec (8h) и maxIdleTime = 0 в c3p0:

Я изменил локальное время ожидания tomcat через файл my.ini на 120 секунд (2 минуты). И я разместил следующее:
maxIdleTime = 100
idleConnectionTestPeriod = 0 (то же, что по умолчанию / как если бы он не существовал)
другое:
acquIncrement = 2
minPoolSize = 2
maxPoolSize = 5
maxIdleTimeExcessConnections = 10

У меня не было проблем с этой настройкой.

Мне не нужно было использовать idleConnectionTestPeriod!

Если время ожидания tomcat составляет 28800 секунд, а maxIdleTime - 25200, это означает, что c3p0 закроет простаивающее соединение на 3600 секунд (1 час) раньше, прежде чем tomcat выдаст исключение «сломанной трубы». Не правда ли ?!

Как видите, у меня нет проблем с предоставлением только maxIdleTime.

К сожалению, это:
maxIdleTime
idleConnectionTestPeriod
configuring_connection_testing
testConnectionOnCheckin
не объясняйте слишком много угловых случаев.

И, кстати, вот как открыть файл my.ini tomcat с помощью Notepad ++: http://drupal.org/node/32715#comment-4907440

Привет, Деспот

person despot    schedule 18.09.2012

У меня несколько проблем - - 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>

- У меня проблема с wait_timeout на mysql. Сначала я установил /etc/my.cnf wait_timeout = 10, затем изменил значение тайм-аута простоя на меньшее, чем значение wait_timeout, которое ‹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;"/>
person Imtiaz Mirza    schedule 20.04.2012

У меня возникла та же проблема, и потребовалось время, чтобы найти решение.

Я использую Hibernate 4.0.1 и mysql 5.1 (без Spring framework), и я столкнулся с проблемой. Сначала убедитесь, что вы правильно настроили jar-файлы 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. Вы можете проверить это в журналах. Итак, я искал подходящее решение на многих веб-сайтах и ​​наконец нашел его. удалите свойства C3p0 в cfg.xml и создайте 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

Надеюсь, это решит вашу проблему.

person chaitanya89    schedule 12.06.2013