2012-05-15 1 views
1

Я использую spring/hibernate интегрированное приложение. У меня настроен пул соединений c3p0. проблема в том, что если я установил свойства c3p0 в разделе свойств hibernate, тогда эти свойства не учитываются и конфигурация по умолчанию выполнена. если я устанавливаю те же свойства для комбинированного источника данных, то они рассматриваются. где находится лучшее место для размещения c3p0 объектов.Где разместить свойства c3p0 в файле конфигурации?

Ниже конфигурации работы:

<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"> 
     <property name="driverClass" value="${db.driverClassName}" /> 
     <property name="jdbcUrl" value="${db.url}" /> 
     <property name="user" value="${db.username}" /> 
     <property name="password" value="${db.password}" /> 

     <!-- c3p0 properties --> 

     <property name="minPoolSize" value="5" /> 
     <property name="maxPoolSize" value="20" /> 
     <property name="maxStatements" value="0" /> 
     <property name="preferredTestQuery" value="select * from sometable" /> 
     </bean> 

    <bean name="wygSessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> 
     <property name="dataSource" ref="dataSource"/> 
     <property name="mappingLocations" value="classpath:hibernate/module/*.hbm.xml" /> 
     <property name="hibernateProperties"> 
      <props> 
       <prop key="hibernate.cache.provider_class">org.hibernate.cache.NoCacheProvider</prop> 
       <prop key="hibernate.connection.pool.size">20</prop> 
       <prop key="hibernate.dialect">org.hibernate.dialect.OracleDialect</prop> 
       <prop key="hibernate.show_sql">true</prop> 
       <prop key="hibernate.format_sql">true</prop> 

         </props> 
     </property> 
    </bean> 

Это не работает:

<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"> 
     <property name="driverClass" value="${db.driverClassName}" /> 
     <property name="jdbcUrl" value="${db.url}" /> 
     <property name="user" value="${db.username}" /> 
     <property name="password" value="${db.password}" /> 

       </bean> 

    <bean name="wygSessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> 
     <property name="dataSource" ref="dataSource"/> 
     <property name="mappingLocations" value="classpath:hibernate/module/*.hbm.xml" /> 
     <property name="hibernateProperties"> 
      <props> 
       <prop key="hibernate.cache.provider_class">org.hibernate.cache.NoCacheProvider</prop> 
       <prop key="hibernate.connection.pool.size">20</prop> 
       <prop key="hibernate.dialect">org.hibernate.dialect.OracleDialect</prop> 
       <prop key="hibernate.show_sql">true</prop> 
       <prop key="hibernate.format_sql">true</prop> 
<!-- c3p0 properties --> 
       <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">0</prop> 
       <prop key="hibernate.c3p0.preferredTestQuery">select * from sometable</prop> 

         </props> 
     </property> 
    </bean> 
+0

Что в первой форме «размер пула» определяет дубликат? (в 'c3p0' источниках данных и' hibernate' proeprties.) Я предполагаю, что если вы определяете все свойства источника данных в свойствах спящего режима, во второй форме это нормально работает. – MJM

+0

Возможный дубликат [где должны быть заданы свойства c3p0?] (Http://stackoverflow.com/questions/10553797/where-should-c3p0-properties-specified) –

ответ

1

я получаю ту же проблему, и потребовалось время, чтобы выяснить решение.

Я использую Hibernate 4.0.1 и mysql 5.1 (без пружинного фреймворка), и я столкнулся с проблемой. Сначала убедитесь, что вы правильно сконфигурировали банки 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

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