以下是一个小应用的数据库连接池配置,包括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配置实例的更多相关文章

  1. spring中通过JNDI、DBCP、C3P0配置数据源

    JNDI配置数据源 1.首先在tomcat的server.xml中配置数据源信息,找到Context,然后在里边加入如下代码 <Context docBase="SpringDemo& ...

  2. 【先定一个小目标】Postgresql允许远程访问配置修改

    1.解决不能连接远程postgresql: postgresql默认情况下,远程访问不能成功,如果需要允许远程访问,需要修改两个配置文件,说明如下: 1.postgresql.conf 将该文件中的l ...

  3. JNDI学习总结(3)——Tomcat下使用C3P0配置JNDI数据源

    一.C3P0下载 C3P0下载地址:http://sourceforge.net/projects/c3p0/files/?source=navbar 下载完成之后得到一个压缩包. 二.使用C3P0配 ...

  4. mysql url 连接配置的一个小坑。 工作中不会遇到。 学习的时候会

    <property name="driverClassName"> <value>com.mysql.jdbc.Driver</value> & ...

  5. 痞子衡嵌入式:关于i.MXRT中FlexSPI外设lookupTable里配置Normal read的一个小误区

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRT中FlexSPI外设lookupTable里配置Normal read的一个小误区. 关于串行四线NOR Flash,当其作 ...

  6. 解密httpclient,dbcp,jedis,c3p0,druid,okhttp都在使用的连接池技术

    最近在连接池上面栽了个跟头(参见这里),引起我对池技术的强烈关注,这几天总结了一下很多场景都会使用的池技术: 池概念 pool,中文翻译为水池,但是在英文中,还有一种解释是 an organizati ...

  7. .数据库连接池技术:DBCP和C3P0

    数据库连接池技术:DBCP和C3P0 1.什么是数据库连接池 已知的方法是需要访问数据库的时候进行一次数据库的连接,对数据库操作完之后再释放这个连接,通常这样业务是缺点很明显的: 用户每次请求都需要向 ...

  8. jdbc基础 (五) 连接池与数据源 DBCP以及C3P0的使用

    一.连接池的概念和使用 在实际应用开发中,特别是在WEB应用系统中,如果JSP.Servlet或EJB使用JDBC直接访问数据库中的数据,每一次数据访问请求都必须经历建立数据库连接.打开数据库.存取数 ...

  9. JNDI学习总结(二)——Tomcat下使用C3P0配置JNDI数据源

    一.C3P0下载 C3P0下载地址:http://sourceforge.net/projects/c3p0/files/?source=navbar

随机推荐

  1. C# 刷票程序

    上个月有人让我帮忙投票,我想要不写个程序给他多刷点得了,虽然这事情有悖原则,就当娱乐了.. 先上图 1.分析 既然是网页投票,那肯定可以伪造HTTP请求来实现刷票.需要分析的就是该网站到底采用了哪些防 ...

  2. Winform将网页生成图片

    今天无意见看到浏览器有将网页生成图片的功能,顿时赶脚很好奇,于是就找了找资料自己做了一个类似的功能. 工具截图:生成后的图片 手动填写网站地址,可选择图片类型和保持图片地址,来生成页面的图片,当图片路 ...

  3. 查看MYSQL数据库中所有用户及拥有权限

    查看MYSQL数据库中所有用户 mysql> SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM m ...

  4. Daject初探 - 从Table模型得到Record模型

    前言: 如果你还不知道Daject是什么,如何使用,可以浏览 http://www.cnblogs.com/kason/p/3577359.html github地址:https://github.c ...

  5. 【学习总结】声明变量在@interface括号中与使用@property的区别

    方式一:直接在.h文件@interface中的大括号中声明. @interface Test : NSObject { NSString *str; // 私有变量 , 其他类无法访问,只能够该类内部 ...

  6. iOS 计算 日期 距离 当前 系统的日期 相差 多少

    #pragma mark - 时间计算函数 - (NSTimeInterval)intervalSinceNow:(NSString *) theDate { NSDateFormatter * da ...

  7. MVC的Ajax的异步请求

    MVC的Ajax的异步请求 在这里小写一下MVC的异步请求的一点小总结. 个人认为是有两种的,一种就是跟webform一样的,依旧是使用jQuery的$.get()方法,只是请求地址不同,webfor ...

  8. Text selection in div(contenteditable) when double click

    背景: 在最近项目中,碰到一个问题:有一个可编辑的div需要双击时可编辑,blur或者回车时将编辑结果保存.你可能注意到双击时,文字会被选中,可编辑区域不会focus到光标位置.考虑到兼容性问题,写了 ...

  9. pos机套现是怎么回事

    POS机是商家为了促进消费,向银行申请的刷卡机它的主要功能是转账就是通过客户的刷卡,把相对的金额转入商户的帐户银行会根据笔数或金额向商户收取手续费非法套现就是客户并未和商户产生贸易往来,单纯通过pos ...

  10. 【BZOJ】【3143】【HNOI2013】游走

    数学期望/高斯消元/贪心 啊……用贪心的思路明显是要把经过次数期望越大的边的权值定的越小,那么接下来的任务就是求每条边的期望经过次数. 拆边为点?nonono,连接x,y两点的边的期望经过次数明显是 ...