Я получил эту ошибку из кода продукции:ВОПРОИЗВЕДЕНИЕ com.mysql.jdbc.exceptions.jdbc4.CommunicationsException с установкой весны, спящий режим и C3P0
com.mysql.jdbc.exceptions.jdbc4.CommunicationsException : последний пакет успешно принят от сервера was36940 секунд ago.The последнего пакета успешно отправлен на сервер были 36940 секунд назад, , который длиннее, чем сервер сконфигурирован значения «wait_timeout». Вы должны рассмотреть либо истекающего и/или соединение тестирования достоверности перед использованием в приложении, увеличивая сервер настроен значения для клиента тайм-аута, или с помощью разъема/J подключение свойство «autoReconnect = истина», чтобы избежать этого проблема.
И теперь я пытаюсь воспроизвести проблему локально и исправить ее. Я настроить контекст пружины следующим образом:
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
destroy-method="close" p:driverClass="com.mysql.jdbc.Driver"
p:jdbcUrl="jdbc:mysql://localhost:3306/test?userUnicode=yes&characterEncoding=UTF-8&"
p:idleConnectionTestPeriod="120" p:initialPoolSize="1" p:maxIdleTime="1800"
p:maxPoolSize="1" p:minPoolSize="1" p:checkoutTimeout="1000"
/>
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="hibernateProperties">
<value>
hibernate.connection.provider_class = org.hibernate.connection.C3P0ConnectionProvider
hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
hibernate.default_schema=platform_server_original
hibernate.show_sql=false
</value>
</property>
<property name="mappingResources">
<list>
<value>sometables.hbm.xml</value>
</list>
</property>
</bean>
Затем я установил мой MySQL WAIT_TIMEOUT до 10 секунд, а затем запустить мой тест, который является в основном открыть соединение, сделать запрос, закройте его, так что он возвращается в пул , затем снизьте поток в течение 15 секунд, а затем снова откройте соединение и снова выполните запрос, чтобы он сломался. Тем не менее, я получил подобную ошибку только:
com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: связи Отказ канала
Последний пакет, отправленный на сервер был 16 мс назад.
Так что я думаю, эти две ошибки одинаковы или они разные? Я сделал несколько исследований, и, похоже, обе ошибки сводились к одному и тому же решению: с использованием свойства «testConnectionOnCheckout = true». Однако, согласно документу c3p0, это очень дорогая проверка. Он советует использовать «idleConnectionTestPeriod», но я уже устанавливаю его на 120 секунд. Какое значение я должен использовать, чтобы он мог корректно проверить соединение в режиме ожидания?
Так что я в основном задаю две вещи: 1. Как воспроизвести ошибку, которую я получил в производственном коде? 2. Как его исправить?
Спасибо!
Вашей первоначальная ошибка от производства говорит о периоде времени, в течение 10 часов и происходит, когда соединение извлеченное когда система первой используется утром? Разве вы не можете установить минимальный размер пула на 0 или разоблачить пул через JXB и сбросить его до начала рабочего дня? – SteveD
@fei - Вы разрешили это? Будьте заинтересованы, чтобы узнать, каков был результат. –
Я закончил использовать следующие 2 свойства: testConnectionOnCheckout = "true" preferredTestQuery = "select 1" Не самое оптимальное решение, но оно решает проблему как минимум. – fei