标签:
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>
标签:
原文地址:http://www.cnblogs.com/yanghongkuan/p/5580586.html