2012-05-15 109 views
1

我正在使用spring/hibernate集成應用程序。我配置了c3p0連接池。問題是如果我在hibernate屬性部分中設置c3p0屬性,那麼不考慮這些屬性並採取默認配置。如果我爲combopooled數據源設置了相同的屬性,那麼就會考慮它們。哪裏是放置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中。)我猜如果你在第二種形式中定義了hibernate屬性中的所有數據源屬性,它就可以正常工作。 – 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設置的屬性,你可以在日誌中檢查它。所以,我搜索了很多網站的正確解決方案,最後我想出了這個。刪除cfg.xml中的C3p0屬性,並在根路徑(以及cfg.xml)中創建c3p0-config.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

我希望這能解決你的問題。