Spring配置数据源的几种形式
由于我的网站之前用的c3p0数据连接池配置,总是引发一些莫名其妙的错误,几次内存泄漏都和这个有关系,google之发现好多人都发现了这些bug.
于是了解了一下常见的数据源的配置,并改成了dbcp的配置方案。
Spring中提供了4种不同形式的数据源配置方式:
1、Spring自带的数据源(DriverMangerDataSource);
2、DBCP数据源;
3、C3P0数据源;
4、JNDI数据源。
以上数据源配置需要用的Jar包在http://www.java2s.com/Code/Jar/c/Catalogc.htm中都可以下载到
下面详细介绍这四种数据源配置方式:
1. DriverMangerDataSource
使用org.springframework.jdbc.datasource.DriverManagerDataSource
说明:DriverManagerDataSource建立连接是只要有连接就新建一个connection,根本没有连接池的作用。
XML代码
1 | <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> |
2.DBCP数据源
使用org.apache.commons.dbcp.BasicDataSource
说明:这是一种推荐说明的数据源配置方式,它真正使用了连接池技术DBCP的配置依赖于2个jar包commons-dbcp.jar,commons-pool.jar。
XML代码:
1 | <!-- 使用org.apache.commons.dbcp.BasicDataSource |
上面代码的解释:
BasicDataSource提供了close()方法关闭数据源,所以必须设定destroy-method=”close”属性,
以便Spring容器关闭时,数据源能够正常关闭。除以上必须的数据源属性外,还有一些常用的属性:defaultAutoCommit:设置从数据源中返回的连接是否采用自动提交机制,默认值为 true;
defaultReadOnly:设置数据源是否仅能执行只读操作, 默认值为 false;
maxActive:最大连接数据库连接数,设置为0时,表示没有限制; maxIdle:最大等待连接中的数量,设置为0时,表示没有限制;
maxWait:最大等待秒数,单位为毫秒, 超过时间会报出错误信息;
validationQuery:用于验证连接是否成功的查询SQL语句,SQL语句必须至少要返回一行数据,
如你可以简单地设置为:“select count(*) from user”; removeAbandoned:是否自我中断,默认是
false ;
removeAbandonedTimeout:几秒后数据连接会自动断开,在removeAbandoned为true,提供该值;
logAbandoned:是否记录中断事件, 默认为 false;
3.C3P0数据源
C3P0是一个开放源代码的JDBC数据源实现项目,C3P0依赖于jar包c3p0.jar。
XML代码:
1 | <!-- 配置数据源 c3p0 --> |
4.JNDI数据源
使用org.springframework.jndi.JndiObjectFactoryBean
说明:JndiObjectFactoryBean 能够通过JNDI获取DataSource
如果应用配置在高性能的应用服务器(如WebLogic或Websphere,tomcat等)上,我们可能更希望使用应用服务器本身提供的数据源。应用服务器的数据源
使用JNDI开放调用者使用,Spring为此专门提供引用JNDI资源的JndiObjectFactoryBean类。
xml 代码:
1 | <bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean"> |