Соединения с базой данных не закрываются - PullRequest
4 голосов
/ 15 ноября 2011

Я использую Spring 3.0 (jdbcTemplate), Tomcat, MySQL и C3p0 для обработки моих операций с базами данных. Я использую как jdbctemplate, так и simplejdbctemplate, который позаботится о создании и закрытии соединений, операторов, наборов результатов и т. Д. Я использую C3p0 для пула соединений, однако соединения остаются открытыми, и в конечном итоге в приложении не будет соединений.

Вот конфигурация моего источника данных:

<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close" >
        <property name="driverClass" value="${jdbc.driverClassName}"></property>
        <property name="jdbcUrl" value="${jdbc.url}"></property>
        <property name="user" value="${jdbc.username}"></property>
        <property name="password" value="${jdbc.password}"></property>
        <property name="initialPoolSize" value="5"></property>
        <property name="maxPoolSize" value="100"/>
        <property name="minPoolSize" value="5"/>
        <property name="maxIdleTime" value="30"/>
        <property name="maxIdleTimeExcessConnections" value="30"/>
        <property name="maxConnectionAge" value="30"/>
        <property name="checkoutTimeout" value="100"/>
        <property name="maxStatements" value="50"></property>
        <property name="automaticTestTable" value="C3P0_TEST_TABLE"></property>
        <property name="testConnectionOnCheckin" value="true"></property>
        <property name="idleConnectionTestPeriod" value="30"></property> 
    </bean>

Я также использую TransactionManagement, предоставляемый spring - вот его конфигурация:

 <!-- enable the configuration of transactional behavior based on annotations -->
   <tx:annotation-driven transaction-manager="txManager"/>

   <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
   </bean>

Вот остальные настройки источника данных:

 <bean id="simpleJdbcTemplate" class="org.springframework.jdbc.core.simple.SimpleJdbcTemplate">
        <constructor-arg><ref bean="dataSource"/></constructor-arg>
   </bean>
   <bean id="userDAO" class="com.Test.dao.UserDAOImpl">
        <property name="jdbcTemplate"><ref bean="jdbcTemplate"/></property>
   </bean>

Наконец, вот метод, с помощью которого я обновляю записи в базе данных:

@Transactional(readOnly=false)
public void updateBenchMarkCumulative(List<BenchMarkCumulative> bmCumulativeList)
{
    List<Object[]> parameters = new ArrayList<Object[]>();
    for(BenchMarkCumulative bmCumulative : bmCumulativeList)
    {
        parameters.add(new Object[]{bmCumulative.getCumulativeAmt(), bmCumulative.getPkBenchMarkCumulative()});
    }
    this.simpleJdbcTemplate.batchUpdate(UPDATE_BENCHMARK_CUMULATIVE, parameters);
}

Есть ли что-то, что я делаю неправильно в моей конфигурации, или мне не хватает чего-то, что нужно добавить в конфигурацию или кодирование?

Вот исключение:

 INFO [http-8080-1] (AbstractPoolBackedDataSource.java510) - Initializing c3p0 pool... com.mchange.v2.c3p0.ComboPooledDataSource [ java.beans.IntrospectionException: java.lang.reflect.InvocationTargetException [numThreadsAwaitingCheckoutDefaultUser] ]


org.springframework.transaction.CannotCreateTransactionException: Could not open JDBC Connection for transaction; nested exception is com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Data source rejected establishment of connection,  message from server: "Too many connections"

Заранее спасибо. Кит

1 Ответ

0 голосов
/ 16 ноября 2011

Я бы согласился с axtavt.Я был в подобной ситуации, и было несколько мест, где я вручную открывал соединения, но не закрывал их (вызовы хранимых процедур для iSeries).Пожалуйста, проверьте, если у вас есть такие пятна.

...