一个小应用的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
随机推荐
- wrk 网站压力测试
下载安装 wrk [root@aikaiyuan ~]# git clone https://github.com/wg/wrk.gitInitialized empty Git repository ...
- Java对象的序列化与反序列化
序列化与反序列化 序列化 (Serialization)是将对象的状态信息转换为可以存储或传输的形式的过程.一般将一个对象存储至一个储存媒介,例如档案或是记亿体缓冲等.在网络传输过程中,可以是字节或是 ...
- SSH与EJB 比较
SSH完全的开源产品,如果用SSH就必然会用到大量的开源的东东,从数据库到逻辑到控制到前端,开源产品大拼装, 其中SSH中的三大核心,Struts相当于JSF,spring相当于EJB,hiberna ...
- 微信wap开发,页面显示元素不全-微信开发(asp.net)
最近在开发的微信的微商城,出现这样一种情况: pc上浏览正常,但是一到手机上浏览就会缺少部分元素 解决办法: 找了很多原因,还通过uc浏览器把网页到存下来了,发现并没有缺少元素,只是没有显示出来,后来 ...
- Flv 视频格式(转)
最近要用到flv,整理了一些flv格式的资料,供参考. flv文件主要由两部分组成:header和body. 1.header header部分记录了flv的类型.版本等信息,是flv的开头,一般都差 ...
- 【环境】Linux下连接无线网常用命令
启用/重启/关闭 网络服务 /etc/init.d/networking start /etc/init.d/networking restart /etc/init.d/networking sto ...
- Netty 中文教程 Hello World !详解
1.HelloServer 详解 HelloServer首先定义了一个静态终态的变量---服务端绑定端口7878.至于为什么是这个7878端口,纯粹是笔者个人喜好.大家可以按照自己的习惯选择端口.当然 ...
- c++ 枚举 在函数中的应用
#include <iostream> using namespace std; enum RespErrNo { SUCCESS = , INVALID_URL = , INVALID_ ...
- "Could not load type 'System.Runtime.CompilerServices.ExtensionAttribute' from assembly 'mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b7
1.错误背景 系统安装了.net framework4.0.4.5,项目先使用VS2013(4.5)开发,后来又重新用VS2010开发(4.0),运行时出现这个错误 2.错误原因 In .Net 4. ...
- git如何ignore
今天新建了一个项目传到git上,但是每次编译都会有一些无用的文件生成,于是就编写了ignore.但是发现无用.因为你的文件已经上传到服务器了,再编写ignore就无用了,ignore的适用是文件没上传 ...