Ниже приводится сведения о конфигурации:Hibernate не отпуская базовые соединения данных
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.Oracle9iDialect
</prop>
<prop key="hibernate.show_sql">false</prop>
<prop key="hibernate.cache.provider_class">
org.hibernate.cache.OSCacheProvider
</prop>
<prop key="hibernate.cache.use_second_level_cache">
true
</prop>
<!-- <prop key="hibernate.hbm2ddl.auto">update</prop>-->
<!-- HIBERNATE CONNECTION POOLING!!-->
<prop key="c3p0.acquire_increment">5</prop>
<prop key="c3p0.idle_test_period">100</prop>
<!-- seconds -->
<prop key="c3p0.max_statements">5</prop>
<prop key="c3p0.min_size">15</prop>
<prop key="c3p0.max_size">100</prop>
<prop key="c3p0.timeout">100</prop>
<!-- seconds -->
</props>
</property>
Наше приложение разработано с помощью Spring & гибернации.
Как только мы приносим приложение и ударяем его, он открывает 140 соединений и не отпускает его.
Наша DAO выглядит следующим образом:
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;
...
public class ActionDAO extends HibernateDaoSupport implements IActionDAO {
public Action findById(ActionPK actionPK) {
return (Action) getHibernateTemplate().get(Action.class, actionPK);
}
public void add(Action action) {
getHibernateTemplate().save(action);
}
}
Мы сталкиваемся с той же ситуацией ранее в нашем проекте. После недели поиска в Интернете и большого количества сообщений в форуме мы не могли понять проблему. Для целей тестирования мы устанавливаем кеш второго уровня «false», и система работает. Ehcache используется в нашем проекте. Я пытаюсь выяснить проблему, но она все еще викторирует меня. Попробуйте, возможно, это сработает. – Shashi
Что такое версия Hibernate? – Shashi