spring 及 hibernate 的数据库连接池管理

最近一直在分析SSH框架的数据库连接池配置,见不同的项目有不同的数据库连接池配置,有的是在sessionFactory中配置连接池大小等参数,有的是在datasource中配置,问题来了,datasource作为一个数据源,所有连接均从datasource中获取,所以数据库连接池配置这里没有疑问。另一种情况,如果是配置在sessionFactory中是不是意味着这个池子由hibernate来管理(绑定sesssion,处理缓存等)?sessionFactory只用从dataSource中拿连接,也就是说datasource只负责提供连接不提供池子呢。

第一种情况配置:

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName">
    <value>com.mysql.jdbc.Driver</value>
</property>
<property name="url">
    <value>jdbc:mysql://localhost:3306/dbname</value>
</property>
<property name="username">
     <value>root</value>
</property>
<property name="password">
     <value>******</value>
</property>
<property name="maxActive">  

     <value>100</value>
</property>
<property name="maxWait">

     <value>1000</value>
</property>
<property name="maxIdle">
     <value>30</value>
</property>

<property name="defaultAutoCommit">
     <value>true</value>  
</property>
<property name="removeAbandoned"> //自动回收连接池,避免连接池泄露
     <value>true</value>
</property>
<property name="removeAbandonedTimeout">
     <value>60</value>
</property>
</bean>


第二种配置:

<bean id="sessionFactory"
        class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
        <property name="dataSource">
            <ref local="dataSource" />
        </property>
        
        <property name="mappingLocations">
            <list>
                <value>/WEB-INF/classes/fi/**/*.hbm.xml</value>
            </list>
        </property>
        <property name="mappingJarLocations">
            <list>
                <value>/WEB-INF/lib/fbi.jar</value>
            </list>
        </property>
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.show_sql">true</prop>
                <prop key="hibernate.dialect">
                    <!--
                    org.hibernate.dialect.DmDialect
                     -->
                    org.hibernate.dialect.MySQLInnoDBDialect
                </prop>
                <!-- <prop key="connection.pool_size">15</prop> -->
                <!-- <prop key="hibernate.generate_statistics">true</prop> -->
                <!-- <prop key="hibernate.jdbc.fetch_size">50</prop> -->
                <prop key="hibernate.jdbc.batch_size">25</prop>
                <prop key="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</prop>
            </props>
        </property>
        <property name="eventListeners">
            <map>
                <entry key="merge">
                    <bean
                        class="org.springframework.orm.hibernate3.support.IdTransferringMergeEventListener" />
                </entry>
            </map>
        </property>
    </bean>


其实第二个配置有点误导的意思,真正的datasource是用来建立数据库连接池的,sessionfactory是从datasource中取的连接的,当然sessionfactory可以对datasource重新进行初始化配置(池子大小等属性)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值