свойства пула соединений c3p0 не установлены?

Я использую приложение spring/hibernate и настроил пул соединений c3p0. Пул соединений c3p0 включен. я проверил свои журналы.

10 May 2012 14:55:56  INFO AbstractPoolBackedDataSource:462 - Initializing c3p0 pool... com.mchange.v2.c3p0.ComboPooledDataSource 

Но проблема в том, что программно я получаю настроенный источник данных и пытаюсь увидеть его свойства, но какие бы свойства я ни устанавливал в файле конфигурации, они не установлены. Ниже приведены конфигурация и отлаженные значения.

<prop key="hibernate.connection.pool.size">20</prop>
                <prop key="hibernate.show_sql">true</prop>
                <prop key="hibernate.format_sql">true</prop>
                <prop key="hibernate.use_sql_comments">true</prop>
                <prop key="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</prop>
                <prop key="hibernate.c3p0.min_size">5</prop>
                <prop key="hibernate.c3p0.max_size">20</prop>
                <prop key="hibernate.c3p0.timeout">300</prop>
                <prop key="hibernate.c3p0.max_statements">50</prop>
                <prop key="hibernate.c3p0.idle_test_period">3000</prop>
                <prop key="hibernate.jdbc.batch_size">50</prop>
                <prop key="hibernate.c3p0.preferredTestQuery">SELECT GETDATE()</prop>
                 <prop key="hibernate.c3p0.testConnectionOnCheckout">true</prop>

отлаженные значения:

введите здесь описание изображения

я получаю источник данных, как показано ниже.

    WebApplicationContext context = WebApplicationContextUtils.getRequiredWebApplicationContext(getServletContext());
.......getBean("datasourceId");
..................

в свойствах я устанавливаю предпочтительный тестовый запрос. это также пусто на изображении.

я пропустил что-нибудь здесь. Спасибо!


person user1016403    schedule 11.05.2012    source источник
comment
можете ли вы проверить, установлены ли эти свойства в nextDataSource   -  person rascio    schedule 11.05.2012
comment
Я проверил, что там тоже нет.   -  person user1016403    schedule 11.05.2012


Ответы (3)


Я использую его следующим образом

<bean id="sessionFactory"  class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
    <property name="dataSource" ref="pooledConn"/>
    <property name="hibernateProperties">
       <props>
         <prop key="hibernate.dialect" >${HIBERNATE.DIALECT}</prop>
        <!--  <prop key="hibernate.show_sql">${HIBERNATE.SHOW_SQL}</prop> -->
          <prop key="hibernate.show_sql">true</prop>
         <prop key="hibernate.hbm2ddl.auto">${HIBERNATE.hBM2DDL.AUTO}</prop>   
       </props>
    </property> 

и это работает абсолютно идеально для меня, не могли бы вы вставить свою конфигурацию для получения дополнительной помощи

person Akash Yadav    schedule 11.05.2012

Попробуйте добавить в файл конфигурации следующее:

<prop key="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</prop>
person Aviram    schedule 11.05.2012

У меня возникла та же проблема, и мне потребовалось время, чтобы найти решение.

Я использую Hibernate 4.0.1 и mysql 5.1 (без Spring Framework), и я столкнулся с проблемой. Сначала убедитесь, что вы правильно настроили jar-файлы c3p0, которые необходимы.

Я использовал эти свойства в hibernate.cfg.xml.

<property name="hibernate.c3p0.validate">true</property>
<property name="hibernate.connection.provider_class">org.hibernate.service.jdbc.connections.internal.C3P0ConnectionProvider</property>
<property name="hibernate.c3p0.min_size">5</property>
<property name="hibernate.c3p0.max_size">20</property>
<property name="hibernate.c3p0.max_statements">50</property>
<property name="hibernate.c3p0.preferredTestQuery">SELECT 1;</property>
<property name="hibernate.c3p0.testConnectionOnCheckout">true</property>
<property name="hibernate.c3p0.idle_test_period">10</property>
<property name="hibernate.c3p0.acquireRetryAttempts">5</property>
<property name="hibernate.c3p0.acquireRetryDelay">200</property>
<property name="hibernate.c3p0.timeout">40</property>

Но это бесполезно, потому что C3p0 по-прежнему использует свойства по умолчанию, а не свойства, которые я установил в hibernate.cfg.xml. Вы можете проверить это в журналах. Итак, я искал на многих веб-сайтах правильное решение и, наконец, нашел это. удалите свойства C3p0 в cfg.xml и создайте c3p0-config.xml в корневом пути (вместе с cfg.xml) и установите свойства следующим образом.

<c3p0-config>
<default-config> 
<property name="automaticTestTable">con_test</property>
<property name="checkoutTimeout">40</property> 
<property name="idleConnectionTestPeriod">10</property> 
<property name="initialPoolSize">10</property>
<property name="maxPoolSize">20</property> 
<property name="minPoolSize">5</property> 
<property name="maxStatements">50</property>
<property name="preferredTestQuery">SELECT 1;</property>
<property name="acquireRetryAttempts">5</property>
<property name="acquireRetryDelay">200</property>
<property name="maxIdleTime">30</property>
</default-config>
</c3p0-config>

но если вы запустите, ORM использует соединение jdbc, но не пул соединений C3p0, потому что мы должны добавить эти свойства в hibernate.cfg.xml

<property name="hibernate.c3p0.validate">true</property>

<property name="hibernate.connection.provider_class">org.hibernate.service.jdbc.connections.internal.C3P0ConnectionProvider</property>

теперь все работает нормально (по крайней мере у меня работало нормально) и проблема решена.

проверьте следующее для ссылок.

http://www.mchange.com/projects/c3p0/index.html#configuring_connection_testing

https://community.jboss.org/wiki/HowToConfigureTheC3P0ConnectionPool

Надеюсь, это решит вашу проблему.

person chaitanya89    schedule 12.06.2013