Spring配置数据源(连接池的三种方式对比)
2018-03-15 10:30
453 查看
本文主要针对以下三种连接池进行分析对比:C3P0
DBCP
JNDI
<property name="preferredTestQuery" value="SELECT 1"/>
<property name="idleConnectionTestPeriod" value="10"/>
<property name="maxIdleTime"value="1800"/>
<property name="testConnectionOnCheckout" value="false"/>
</bean>
preferredTestQuery:定义所有连接测试都执行的测试语句;
idleConnectionTestPeriod:每隔一段时间检查所有连接池中的空闲连接;
maxIdleTime:最大空闲时间,超过这个时间则连接被丢弃;
testConnectionOnCheckout:如果设为true,那么在每个connection提交的时候都将校验其有效性,这将会降低性能,因此需要设置为false,通过配置idleConnectionTestPeriod参数,定时检查;
<property name="testOnBorrow" value="true"></property>
<property name="validationQuery" value="select 1"></property>
</bean>
testOnBorrow:是从数据库连接池中取得连接时,对其的有效性进行检查;
validationQuery:用来检查连接有效性的SQL语句,“select 1”执行较快;
两者主要是对数据连接的处理方式不同,C3P0提供最大空闲时间,DBCP提供最大连接数;
前者当连接超过最大空闲连接时间时,当前连接就会自动断开,DBCP当连接数超过最大连接数时,所有连接都会被断开;
DBCP
JNDI
1.com.mchange.v2.c3p0.ComboPooledDataSource
定期使用连接池内的连接,使得它们不会因为闲置超时而被 MySQL 断开<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"><property name="preferredTestQuery" value="SELECT 1"/>
<property name="idleConnectionTestPeriod" value="10"/>
<property name="maxIdleTime"value="1800"/>
<property name="testConnectionOnCheckout" value="false"/>
</bean>
preferredTestQuery:定义所有连接测试都执行的测试语句;
idleConnectionTestPeriod:每隔一段时间检查所有连接池中的空闲连接;
maxIdleTime:最大空闲时间,超过这个时间则连接被丢弃;
testConnectionOnCheckout:如果设为true,那么在每个connection提交的时候都将校验其有效性,这将会降低性能,因此需要设置为false,通过配置idleConnectionTestPeriod参数,定时检查;
2.org.apache.commons.dbcp.BasicDataSource
BasicDataSource提供了close()方法关闭数据源,需要设定destroy-method=”close”属性, 以便Spring容器关闭时,数据源能够正常关闭;<bean class="org.apache.commons.dbcp.BasicDataSource"><property name="testOnBorrow" value="true"></property>
<property name="validationQuery" value="select 1"></property>
</bean>
testOnBorrow:是从数据库连接池中取得连接时,对其的有效性进行检查;
validationQuery:用来检查连接有效性的SQL语句,“select 1”执行较快;
3.org.springframework.jndi.JndiObjectFactoryBean
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean"> <property name="jndiName"> <value>java:/*</value> </property> </bean>需要在web容器中配置数据源相关参数;
c3p0与dbcp区别:
dbcp没有自动回收空闲连接的功能,c3p0有自动回收空闲连接功能 ;两者主要是对数据连接的处理方式不同,C3P0提供最大空闲时间,DBCP提供最大连接数;
前者当连接超过最大空闲连接时间时,当前连接就会自动断开,DBCP当连接数超过最大连接数时,所有连接都会被断开;
相关文章推荐
- Spring配置数据源的三种方式 (dbcp,c3p0,jndi).
- Spring配置数据源的三种方式
- Spring配置数据源的三种方式 (dbcp,c3p0,jndi)
- Spring —— 三种配置数据源的方式:spring内置、c3p0、dbcp
- Spring学习(二十二) Bean配置的三种方式(XML、注解、Java类)介绍与对比
- Spring配置数据源的三种方式 (dbcp,c3p0,jndi)
- Spring配置数据源的三种方式 (dbcp,c3p0,jndi)
- Spring配置数据源的三种方式
- Spring配置数据源的三种方式
- Spring配置数据源的三种方式 (dbcp,c3p0,jndi).
- Spring配置数据源的三种方式 (dbcp,c3p0,jndi)
- Spring配置数据源的三种方式 (dbcp,c3p0,jndi).
- Spring配置数据源的三种方式 (dbcp,c3p0,jndi)
- Java后台框架篇--Spring配置数据源的三种方式(dbcp,c3p0,jndi)
- jndi3 Spring配置数据源的三种方式 .
- Spring配置数据源的三种方式
- Spring学习----------Bean配置的三种方式(XML、注解、Java类)介绍与对比
- Spring配置数据源的三种方式 (dbcp,c3p0,jndi).
- Spring配置数据源的三种方式 (dbcp,c3p0,jndi).
- spring配置数据源的三种方式