一个小应用的dbcp和c3p0配置实例
以下是一个小应用的数据库连接池配置,包括DBCP和C3P0的配制方法
因为是小应用,完全不涉及访问压力,所以配置上采取尽量节约数据库资源的方式
具体要求如下:
初始化连接数为0
连接不够,需要新创建时,每次创建1个
尽快回收空闲连接
需要开启prepareStatement缓存
具体用代码来说明
package com.yazuo.util; import com.mchange.v2.c3p0.ComboPooledDataSource;
import org.apache.commons.dbcp.BasicDataSource;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.jdbc.core.JdbcTemplate; import java.util.Map; /**
* Created by IntelliJ IDEA.
* User: Luo
* Date: 13-6-19
* Time: 下午3:33
*/
public class JdbcTemplateFactory {
static Logger log = LoggerFactory.getLogger(JdbcTemplateFactory.class); private static JdbcTemplate jdbcTemplate; /**
* 获取单例的jdbcTemplate,基于c3p0
*
* @return
*/
public static JdbcTemplate getJdbcTemplate() {
if (jdbcTemplate == null) {
synchronized (JdbcTemplateFactory.class) {
if (jdbcTemplate == null) {
try {
//读取配置文件
Map<String, String> jdbcProps = PropertiesUtil.getPropertiesMap("jdbc.properties");
//创建连接池
ComboPooledDataSource dataSource = new ComboPooledDataSource();
dataSource.setJdbcUrl(jdbcProps.get("jdbc.url"));
dataSource.setUser(jdbcProps.get("jdbc.username"));
dataSource.setPassword(jdbcProps.get("jdbc.password"));
//默认初始化连接为3,设置为0
dataSource.setInitialPoolSize(0);
//默认每次创建连接数为3,设置为1
dataSource.setAcquireIncrement(1);
//默认最小连接数是3,设置为0
dataSource.setMinPoolSize(0);
//默认最长空闲时间为0,即不会回收空闲连接,设置为10秒
dataSource.setMaxIdleTime(10);
//默认为不开启 prepareStatement 缓存,设置为最大缓存5个
dataSource.setMaxStatements(5);
jdbcTemplate = new JdbcTemplate(dataSource);
} catch (Exception e) {
throw new IllegalStateException("数据库连接创建失败", e);
}
}
}
}
return jdbcTemplate;
} /**
* 获取单例的jdbcTemplate,基于dbcp
*
* @return
*/
public static JdbcTemplate getJdbcTemplateByDbcp() {
if (jdbcTemplate == null) {
synchronized (JdbcTemplateFactory.class) {
if (jdbcTemplate == null) {
try {
//读取配置文件
Map<String, String> jdbcProps = PropertiesUtil.getPropertiesMap("jdbc.properties");
//创建连接池
BasicDataSource dataSource = new BasicDataSource();
dataSource.setUrl(jdbcProps.get("jdbc.url"));
dataSource.setUsername(jdbcProps.get("jdbc.username"));
dataSource.setPassword(jdbcProps.get("jdbc.password"));
dataSource.setInitialSize(3); //默认为不起动回收器,设置为30秒执行一次回收器
dataSource.setTimeBetweenEvictionRunsMillis(30 * 1000);
//默认为30分钟不使用的连接被认为空闲,设置为10秒钟
dataSource.setMinEvictableIdleTimeMillis(10 * 1000);
//开启 prepareStatement 缓存
dataSource.setPoolPreparedStatements(true);
jdbcTemplate = new JdbcTemplate(dataSource);
} catch (Exception e) {
throw new IllegalStateException("数据库连接创建失败", e);
}
}
}
}
return jdbcTemplate;
} }
一个小应用的dbcp和c3p0配置实例的更多相关文章
- spring中通过JNDI、DBCP、C3P0配置数据源
JNDI配置数据源 1.首先在tomcat的server.xml中配置数据源信息,找到Context,然后在里边加入如下代码 <Context docBase="SpringDemo& ...
- 【先定一个小目标】Postgresql允许远程访问配置修改
1.解决不能连接远程postgresql: postgresql默认情况下,远程访问不能成功,如果需要允许远程访问,需要修改两个配置文件,说明如下: 1.postgresql.conf 将该文件中的l ...
- JNDI学习总结(3)——Tomcat下使用C3P0配置JNDI数据源
一.C3P0下载 C3P0下载地址:http://sourceforge.net/projects/c3p0/files/?source=navbar 下载完成之后得到一个压缩包. 二.使用C3P0配 ...
- mysql url 连接配置的一个小坑。 工作中不会遇到。 学习的时候会
<property name="driverClassName"> <value>com.mysql.jdbc.Driver</value> & ...
- 痞子衡嵌入式:关于i.MXRT中FlexSPI外设lookupTable里配置Normal read的一个小误区
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRT中FlexSPI外设lookupTable里配置Normal read的一个小误区. 关于串行四线NOR Flash,当其作 ...
- 解密httpclient,dbcp,jedis,c3p0,druid,okhttp都在使用的连接池技术
最近在连接池上面栽了个跟头(参见这里),引起我对池技术的强烈关注,这几天总结了一下很多场景都会使用的池技术: 池概念 pool,中文翻译为水池,但是在英文中,还有一种解释是 an organizati ...
- .数据库连接池技术:DBCP和C3P0
数据库连接池技术:DBCP和C3P0 1.什么是数据库连接池 已知的方法是需要访问数据库的时候进行一次数据库的连接,对数据库操作完之后再释放这个连接,通常这样业务是缺点很明显的: 用户每次请求都需要向 ...
- jdbc基础 (五) 连接池与数据源 DBCP以及C3P0的使用
一.连接池的概念和使用 在实际应用开发中,特别是在WEB应用系统中,如果JSP.Servlet或EJB使用JDBC直接访问数据库中的数据,每一次数据访问请求都必须经历建立数据库连接.打开数据库.存取数 ...
- JNDI学习总结(二)——Tomcat下使用C3P0配置JNDI数据源
一.C3P0下载 C3P0下载地址:http://sourceforge.net/projects/c3p0/files/?source=navbar
随机推荐
- gif修改背景透明
1.用ImageReady打开,将选中所有帧,右键选择“恢复为背景”. 2.打开“颜色板”,点击左下角的惊叹号,用吸色器点击背景,颜色板自动选中了背景色,将其映射为透明. 3.文件->将优化结果 ...
- ASP.NET中利用Split实现对Checkbox的字符串分离放到DataTable里面
一.背景 昨天唐欢问了我一个问题: 现在有一个CheckBox和一个Label如下图: 要实现选中CheckBox,点击下面打印按钮的时候要做成这个样子的如下图: 简单的说就是档案编号作为表中的一个列 ...
- raiserror的用法
描述:raiserror :是用于抛出一个错误 第一个参数:{ msg_id | msg_str | @local_variable } msg_id:表示可以是一个sys.messages表中定义的 ...
- 【BZOJ 3504】[Cqoi2014]危桥
Description Alice和Bob居住在一个由N座岛屿组成的国家,岛屿被编号为0到N-1.某些岛屿之间有桥相连,桥上的道路是双 向的,但一次只能供一人通行.其中一些桥由于年久失修成为危桥,最多 ...
- easyui toolbar 可以放在datagrid底下
html: <div class="easyui-tabs" style="height: 250px;" tools="#t_rank&quo ...
- .Xresources 配置文件
安装rxvt-unicode-256color,如果不是这个版本的话VIM配色会显示不正常. ~/.Xresources配置文件如下 !urxvt color scheme: URxvt*backgr ...
- [转载+原创]Emgu CV on C# (一) —— Emgu CV on Visual C# 2010
2014-08-16 最近要进行图像识别,准备利用几天的时间研究一下Emgu CV,花了一晚上功夫进行调试环境安装,期间遇到了不少问题,现梳理一下安装过程和调试过程中出现的问题. 中间有转载别人的部分 ...
- 谈谈Android系统启动时的那点事儿
Android系统完整的启动过程,从系统层次角度可分为Linux系统层.Android系统服务层.Zygote进程模型三个阶段:从开机到启动Home Launcher完成具体的任务细节可分为七个步骤, ...
- Oracle 删除表分区
删除表分区(drop partition) 删除表分区包含两种操作,分别是: Ø 删除分区:alter table [tbname] drop partition [ptname] UPDA ...
- javascript 获取父页面中元素对象方法
父页面中: <input type="hidden" id="areaID" value="test1"> <iframe ...