码迷,mamicode.com
首页 > 数据库 > 详细

备忘 - DBCP属性说明

时间:2016-06-13 15:08:37      阅读:209      评论:0      收藏:0      [点我收藏+]

标签:

initialSize :连接池启动时创建的初始化连接数量(默认值为0) 

maxActive :连接池中可同时连接的最大的连接数(默认值为8,调整为20,高峰单机器在20并发左右,自己根据应用场景定) 

maxIdle:连接池中最大的空闲的连接数,超过的空闲连接将被释放,如果设置为负数表示不限制(默认为8个,maxIdle不能设置太小,因为假如在高负载的情况下,连接的打开时间比关闭的时间快,会引起连接池中idle的个数 上升超过maxIdle,而造成频繁连接销毁和创建,类似于jvm参数中的Xmx设置) 

minIdle:连接池中最小的空闲的连接数,低于这个数量会被创建新的连接(默认为0,调整为5,该参数越接近maxIdle,性能越好,因为连接的创建和销毁,都是需要消耗资源的;但是不能太大,因为在机器很空闲的时候,也会创建低于minidle个数的连接,类似于jvm参数中的Xmn设置) 

maxWait  :最大等待时间,当没有可用连接时,连接池等待连接释放的最大时间,超过该时间限制会抛出异常,如果设置-1表示无限等待(默认为无限,调整为60000ms,避免因线程池不够用,而导致请求被无限制挂起) 

poolPreparedStatements:开启池的prepared(默认是false,未调整,经过测试,开启后的性能没有关闭的好。) 

maxOpenPreparedStatements:开启池的prepared 后的同时最大连接数(默认无限制,同上,未配置) 

minEvictableIdleTimeMillis  :连接池中连接,在时间段内一直空闲, 被逐出连接池的时间(默认为30分钟,可以适当做调整,需要和后端服务端的策略配置相关) 

removeAbandonedTimeout  :超过时间限制,回收没有用(废弃)的连接(默认为 300秒,调整为180) 

removeAbandoned  :超过removeAbandonedTimeout时间后,是否进 行没用连接(废弃)的回收(默认为false,调整为true) 

------------------------------------------------------------------------------------------------------------------------------------------------------

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.1.xsd">

<bean id="parentDataSourceMysql" class="org.apache.commons.dbcp.BasicDataSource" abstract="true">
<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
<property name="defaultAutoCommit" value="true"/>
<!--initialSize: 初始化连接-->
<property name="initialSize" value="#{dburlProps[‘mysql.task.initialSize‘]}"/>
<!--maxIdle: 最大空闲连接-->

</beans> 
<property name="maxIdle" value="#{dburlProps[‘mysql.task.maxIdle‘]}"/>
<!--minIdle: 最小空闲连接-->
<property name="minIdle" value="#{dburlProps[‘mysql.task.minIdle‘]}"/>
<!--maxActive: 最大连接数量-->
<property name="maxActive" value="#{dburlProps[‘mysql.task.maxActive‘]}"/>
<!--maxWait: 超时等待时间以毫秒为单位 -->
<property name="maxWait" value="#{dburlProps[‘mysql.task.maxWait‘]}"/>
</bean>
<bean id="dataSourceMysql" parent="parentDataSourceMysql">
<property name="url" value="#{dburlProps[‘mysql.url‘]}"/>
<property name="username" value="#{dbProps[‘mysql.username‘]}" />
<property name="password" value="#{dbProps[‘mysql.password‘]}" />
</bean>

<bean id="sqlSessionFactoryMysql" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="configLocation" value="classpath:mybatis-config-mysql.xml" />
<property name="dataSource" ref="dataSourceMysql" />
</bean>

<bean id="mapperScannerConfigurerTask" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="sqlSessionFactory" ref="sqlSessionFactoryMysql"/>
<property name="basePackage" value="dao目录" />
</bean>

 

备忘 - DBCP属性说明

标签:

原文地址:http://www.cnblogs.com/yanghongkuan/p/5580586.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!