1, Spring指定 datasource
DataSource接口,在javax.sql包,里边有一个getConnection()方法。提供了标准化的取得连接的方式。只要实现了这个接口。Sun这个土鳖定的。
a) 参考文档,找dbcp.BasicDataSource (dbcp:database connection pool数据库连接池)
i. c3p0
ii. dbcp
iii. proxool
b) 在DAO或者Service中注入dataSource
c) 在Spring中可以使用PropertyPlaceHolderConfigure来读取properties文件的内容
在beans.xml配置里写:
<!-- DataSource去哪里读取连接池配置 -->
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<!-- 在src根目录下建jdbc.properties配置文件 -->
<value>classpath:jdbc.properties</value>
</property>
</bean>
DataSource:注意这里使用dbcp,使用dbcp需要2个包:commons-dbcp.jar,commons-pool.jar
<!-- dbcp連接池 ,根据上边的配置去配置文件去读取配置-->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="${jdbc.driverClassName}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
<property name="initialSize" value="5"/>
<property name="maxActive" value="20"/>
</bean>
在src根目录建jdbc.properties配置,名称和DataSource里要一致:
jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/spring
jdbc.username=root
jdbc.password=root
将DataSource数据源注入到DAO:
<bean id="userDAO" class="com.oracle.dao.impl.UserDAOImpl">
<property name="dataSource" ref="dataSource"></property>
</bean>
dbcp连接池配置:
|
<!-- 连接池启动时的初始值 --> <property name="initialSize" value="10"
/> <!-- 连接池的最大值 --> <property name="maxActive" value="100"
/> <!-- 最大空闲值.当经过一个高峰时间后,连接池可以慢慢将已经用不到的连接慢慢释放一部分,一直减少到maxIdle为止
--> <property name="maxIdle" value="50" /> <!--
最小空闲值.当空闲的连接数少于阀值时,连接池就会预申请去一些连接,以免洪峰来时来不及申请 --> <property
name="minIdle" value="10"
/> <!--#给出一条简单的sql语句进行验证--> <property
name="validationQuery" value="select getdate()"
/> <!--#在取出连接时进行有效验证--> <property name="testOnBorrow"
value="true" /> <property name="removeAbandonedTimeout" value="120"
/> <property name="removeAbandoned" value="true" /> <!--
#运行判断连接超时任务的时间间隔,单位为毫秒,默认为-1,即不执行任务。 --> <property
name="timeBetweenEvictionRunsMillis" value="3600000" /> <!--
#连接的超时时间,默认为半小时。 --> <property name="minEvictableIdleTimeMillis"
value="3600000" /> </bean>
(
以下内容摘在springside): DBCP的性能配置主要是4个参数 #连接池启动时的初始值. dbcp.initialSize=10 #连接池的最大值. dbcp.maxActive=50 #最大空闲值.当经过一个高峰时间后,连接池可以慢慢将已经用不到的连接慢慢释放一部分,一直减少到maxIdle为止。 dbcp.maxIdle=20 #最小空闲值.当空闲的连接数少于阀值时,连接池就会预申请去一些连接,以免洪峰来时来不及申请。 dbcp.minIdle=5 一般这几个参数应该放在applicationContext.properties里方便部署时快速修改。 有两种配置风格,
比如较少使用者的管理界面,平时的使用者不多,但瞬时可能会有较多的使用者,如Mini-Web,会设置一个较低的maxIdle
而设置较高的maxActive。
比如长期高负荷运行的业务系统,会设置一个合理的maxIdle值,且maxActive==maxIdle 长期idle连接的处理: Mysql服务端会断开超过8小时的空闲连接,如果系统只在白天工作时间被使用,DBCP的连接就很容易被断开的连接,而且DBCP对jdbc
url里设置autoReconnect=true是无效。 更好的做法DBCP主动断开超时的连接。 #运行判断连接超时任务的时间间隔,单位为毫秒,默认为-1,即不执行任务。 timeBetweenEvictionRunsMillis=3600000 #连接的超时时间,默认为半小时。 minEvictableIdleTimeMillis=3600000 经测试,按上面的设置,DBCP会在连接idle两小时后将其断开。
|