Я делаю проект, объединяющий Hibernate и Spring в веб-приложении Java, используя Tomcat в среде Linux. Из-за проблемы тайм-аута Mysql 8 часов мы хотим использовать C3P0 для управления пулом соединений с нашей базой данных Mysql. Но когда мы его используем, у нас создается множество потоков. Я понял это, потому что при каждом запросе я печатал их все со статусом памяти, который показывает мне увеличение памяти и такие потоки:
- имя: C3P0PooledConnectionPoolManager[identityToken->1hged7o8r13kpj7n1h3ycia|39c446]-HelperThread-#0 демон: настоящая группа! основная группаParent: система активна: истина прервана: ложь
- имя: C3P0PooledConnectionPoolManager[identityToken->1hged7o8r13kpj7n1h3ycia|17ec0e8]-AdminTaskTimer демон: истинная группа! основная группаParent: система активна: истина прервана: ложь
Он может создать более 500 потоков, подобных этим, спустя достаточное время.
Вот мой Hibernate.cfg.xml:
<property name="connection.provider_class">
org.hibernate.connection.C3P0ConnectionProvider</property>
<property name="hibernate.c3p0.acquire_increment">1</property>
<property name="hibernate.c3p0.idle_test_period">5</property>
<property name="hibernate.c3p0.max_size">100</property>
<property name="hibernate.c3p0.max_statements">100</property>
<property name="hibernate.c3p0.min_size">10</property>
<property name="hibernate.c3p0.timeout">5</property>
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/myBase</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password"></property>
<property name="hibernate.hbm2ddl.auto">update</property>
<property name="hibernate.default_schema">myProject</property>
<property name="hibernate.query.factory_class">org.hibernate.hql.classic.ClassicQueryTranslatorFactory</property>
<property name="show_sql">false</property>
<property name="cache.provider_class">
org.hibernate.cache.NoCacheProvider
</property>
Я также попытался добавить файл свойств C3P0, но, кроме уменьшения номера вспомогательного потока, он не удаляет неиспользуемый поток:
c3p0.maxStatements=5
c3p0.maxIdleTime=10
c3p0.numHelperThreads=1
c3p0.testConnectionOnCheckout=true
c3p0.preferredTestQuery=SELECT 1
c3p0.initialPoolSize=1
c3p0.minPoolSize=1
c3p0.maxPoolSize=10
c3p0.acquireIncrement=1
c3p0.idleConnectionTestPeriod=1
Кто-нибудь знает, почему это происходит и как решить эту проблему?
Большое спасибо.