2010-04-14 3 views
0

Я использую Spring 3.0.2, Hibernate 3.5.0 и c3p0 0.9.1.2, и у меня есть тонна ошибок, когда дело доходит до получения соединений и совершения транзакций. Вот моя конфигурация C3P0:c3p0 проблемы управления соединением

<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close"> 
    <property name="driverClass" value="${jdbc.driverClassName}"/> 
    <property name="jdbcUrl" value="${jdbc.url}"/> 
    <property name="properties"> 
     <props> 
      <prop key="c3p0.acquireIncrement">5</prop> 
      <prop key="c3p0.maxIdleTime">30</prop> 
      <prop key="c3p0.idleConnectionTestPeriod">20</prop> 
      <prop key="c3p0.maxPoolSize">100</prop> 
      <prop key="c3p0.maxStatements">0</prop> 
      <prop key="c3p0.minPoolSize">1</prop> 
      <prop key="user">${jdbc.username}</prop> 
      <prop key="password">${jdbc.password}</prop> 
     </props> 
    </property> 
</bean> 

До недавнего времени я получил эту ошибку довольно часто:

com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure 
Last packet sent to the server was 0 ms ago. 

Недавно я также получаю это:

com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Connection.close() has already been called. Invalid operation in this state. 
java.sql.SQLException: Connections could not be acquired from the underlying database! 

Любые предложения?

ответ

0

Возможно, это связано с тем, что соединения синхронизируются. Выполните проверку idle_test_period или используйте bonecp http://jolbox.com, у которого есть разумные значения по умолчанию.

Смежные вопросы