用户每次请求都需要向数据库获得链接,而数据库创建连接通常需要消耗相对较大的资源,创建时间也较长。假设网站一天10万访问量,数据库服务器就需要创建10万次连接,极大的浪费数据库的资源,并且极易造成数据库服务器内存溢出、拓机。

数据库连接是一种关键的有限的昂贵的资源,这一点在多用户的网页应用程序中体现的尤为突出.对数据库连接的管理能显著影响到整个应用程序的伸缩性和健壮性,影响到程序的性能指标.数据库连接池正式针对这个问题提出来的。数据库连接池负责分配,管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是重新建立一个。

一.DBCP数据源

DBCP 是 Apache 软件基金组织下的开源连接池实现,要使用DBCP数据源,需要应用程序应在系统中增加如下两个 jar 文件:

  • Commons-dbcp.jar:连接池的实现
  • Commons-pool.jar:连接池实现的依赖库

Tomcat 的连接池正是采用该连接池来实现的。该数据库连接池既可以与应用服务器整合使用,也可由应用程序独立使用。

1.编写数据库连接池

编写dbcp连接池需实现java.sql.DataSource接口。

public void DBCPtest() throws SQLException{
BasicDataSource datasource=null;
//1.创建DBCP数据源实例
datasource=new BasicDataSource();
//2.为数据源指定必须的属性
datasource.setUsername("root");
datasource.setPassword("0404");
datasource.setUrl("jdbc:mysql://localhost:3303/extra");
datasource.setDriverClassName("com.mysql.jdbc.Driver");
//3.指定数据源的一些可选的属性
//1).指定数据库连接池中初始化连接数的个数
datasource.setInitialSize(10);
//2).指定数据库连接池中最大连接个数:同一时刻可以同时向数据库申请的连接个数
datasource.setMaxTotal(50);
//3).指定最小的连接数
datasource.setMinIdle(5);
//4).等待数据库连接池分配连接的最长时间,单位毫秒,超出抛异常
datasource.setMaxWaitMillis(1000*5);
//4.从数据源中获取数据库连接
Connection connection=datasource.getConnection();
System.out.println(connection);
}

指定的数据源的属性可以放在配置文件中:

username=root
password=0404
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3303/extra initialSize=10
maxTotal=50
minIdle=5
maxWaitMillis=5000

示例代码:

public void testDBCPWithDataSourceFactory() throws Exception{
Properties properties=new Properties();
InputStream inStream=JDBCTest.class.getClassLoader().
getResourceAsStream("dbcp.properties");
properties.load(inStream);
DataSource dataSource=BasicDataSourceFactory.createDataSource(properties);
System.out.println(dataSource.getConnection());
BasicDataSource basicDataSource=(BasicDataSource)dataSource;
System.out.println(basicDataSource.getMaxWaitMillis());
}

上面代码创建jdbc数据库连接池的步骤分为以下几步:

①加载dbcp的properties配置文件:配置文件中的键需要来自BasicDataSource的属性。

②调用BasicDataSourceFactory的createDataSource方法创建DataSource实例。

③从DataSource实例中获取数据库连接。

二.C3P0数据源

C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。目前使用它的开源项目有Hibernate, Spring等。C3P0数据源在项目开发中使用得比较多。

要使用C3P0数据源,需要应用程序应在系统中增加如下两个 jar 文件:

  • c3p0-0.9.2.jar
  • mchange-commons.jar
c3p0与dbcp区别:
  1. dbcp没有自动回收空闲连接的功能
  2. c3p0有自动回收空闲连接功能

1.创建c3p0数据库连接池

public void testC3P0() throws PropertyVetoException, SQLException{
ComboPooledDataSource cpds = new ComboPooledDataSource();
cpds.setDriverClass( "com.mysql.jdbc.Driver" );
cpds.setJdbcUrl( "jdbc:mysql://localhost:3303/extra" );
cpds.setUser("root");
cpds.setPassword("0404");
System.out.println(cpds.getConnection());
}

同样可以将setxxx的属性放置在配置文件中:(c3p0的配置文件的格式为xml)

<c3p0-config>
<named-config name="helloC3P0">
<property name="user">root</property>
<property name="password">0404</property>
<property name="driverClass">com.mysql.jdbc.Driver</property>
<property name="jdbcUrl">jdbc:mysql://localhost:3303/extra</property>
<!-- 若数据库中连接数不足时,一次性向数据库服务器申请多少个连接 -->
<property name="acquireIncrement">50</property>
<!-- 初始化数据库时连接池的个数 -->
<property name="initialPoolSize">100</property>
<!-- 数据库连接池中最小的数据库连接个数 -->
<property name="minPoolSize">50</property>
<property name="maxPoolSize">1000</property>
<!-- c3p0数据库连接池可以维护的Statement的最大的个数 -->
<property name="maxStatements">20</property>
<!-- 每个连接可以使用多少个Statement -->
<property name="maxStatementsPerConnection">5</property>
</named-config>
</c3p0-config>

示例代码:

public void testC3P0WithConfigFile() throws SQLException{
DataSource dataSource=new ComboPooledDataSource("helloC3P0");
System.out.println(dataSource.getConnection());
}

上面代码中:

①创建c3p0-config.xml文件,参考api帮助文档;

②创建ComboPooledDataSource实例:DataSource dataSource=new ComboPooledDataSource("helloC3P0");

③从DataSource实例中获取数据库连接。

至此JDBCTools中的数据库连接方法就可以改为:

private static DataSource dataSource=null;
static{
//数据库连接池应该只被初始化一次
dataSource=new ComboPooledDataSource("helloc3p0");
}
public static Connection getconnection2() throws SQLException{
return dataSource.getConnection();
}

JDBC数据库连接池的更多相关文章

  1. JAVA基础知识之JDBC——JDBC数据库连接池

    JDBC数据库连接池 数据库的连接和关闭是很耗费资源的操作,前面介绍的DriverManager方式获取的数据库连接,一个Connection对象就对应了一个物理数据库连接,每次操作都要打开一个连接, ...

  2. JDBC 数据库连接池

    http://www.cnblogs.com/lihuiyy/archive/2012/02/14/2351768.html JDBC 数据库连接池 小结   当对数据库的访问不是很频繁时,可以在每次 ...

  3. 【Java123】JDBC数据库连接池建立

    需求场景:多SQL任务多线程并行执行 解决方案:建立JDBC数据库连接池,将线程与连接一对一绑定 https://www.cnblogs.com/panxuejun/p/5920845.html ht ...

  4. Java自学-JDBC 数据库连接池

    数据库连接池 与线程池类似的,数据库也有一个数据库连接池. 不过他们的实现思路是不一样的. 本章节讲解了自定义数据库连接池类:ConnectionPool,虽然不是很完善和健壮,但是足以帮助大家理解C ...

  5. JAVA之JDBC数据库连接池总结篇

    JDBC数据库连接池 一.JDBC数据库连接池的必要性 二.数据库连接池技术 三.多种开源的数据库连接池 3.1 C3P0数据库连接池 3.2 DBCP数据库连接池 3.3 Druid(德鲁伊)数据库 ...

  6. JDBC数据库连接池技术

    在JDBC中,获得连接或释放资源是非常消耗系统资源的两个过程,为了解决此类性能问题,通常采用连接池技术,来共享连接.这样我们就不需要每次都创建连接.释放连接了,这些操作都交给了连接池. 用池的概念来管 ...

  7. JDBC 数据库连接池 小结

    原文:http://www.cnblogs.com/lihuiyy/archive/2012/02/14/2351768.html 当对数据库的访问不是很频繁时,可以在每次访问数据库时建立一个连接,用 ...

  8. JDBC数据库连接池原理

    JDBC是java数据库连接的简称.它是一种用于实行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用java语言编写的类和接口组成.其相关的API都在java.sql.*包下 ...

  9. Java jdbc数据库连接池总结!(转)

    1. 引言 近年来,随着Internet/Intranet建网技术的飞速发展和在世界范围内的迅速普及,计算机 应用程序已从传统的桌面应用转到Web应用.基于B/S(Browser/Server)架构的 ...

随机推荐

  1. 操作mysql的指令

    1,通过ip,端口,用户名,密码登陆数据 命令格式为:mysql -h ip -u root -p -P 3306例如:mysql -h 127.0.0.1 -u root -p -P 3306 2, ...

  2. springBoot整合MyBatise及简单应用

    springBoot整合MyBatise及简单应用 我采用的是 工具IDEA 框架是springBoot+maven+Mybatise 第一步: pom.xml 引入相关jar包 <?xml v ...

  3. Swift 函数提前返回

    简评:函数提前返回主要的好处是:将每个错误处理进行分离,审查代码时不需要考虑多种复杂异常,我们可以吧注意力集中在也业务逻辑中,调试代码时可以直接在异常中打断点. 提前返回 首先来看一下需要改进的代码示 ...

  4. leetcode-49-字母异位词分组(神奇的哈希)

    题目描述: 给定一个字符串数组,将字母异位词组合在一起.字母异位词指字母相同,但排列不同的字符串. 示例: 输入: ["eat", "tea", "t ...

  5. python学习,day4:生成器,通过yield实现单线程情况下的并发运算

    首先了解一个斐波那契函数的实现,了解下生成器的工作流程 # coding=utf-8 # Author: RyAn Bi def fib(max): n,a,b=0,0,1 while n < ...

  6. [温故]图解java多线程设计模式(一)

    去年看完的<图解java多线程设计模式>,可惜当时没做笔记,导致后来忘了许多东西,打算再温习下这本书,顺便在这里记录一下~  1.顺序执行.并行.并发 顺序执行:多个操作按照顺序依次执行. ...

  7. jsp页面struts2标签展示clob类型的数据

    直接从数据库中查出来的数据,是clob类型的在前端页面展示的时候是这样: 后来找到了一个方法,在action中添加一个方法,解析转换clob数据的方法 public String getClob(Cl ...

  8. SCOI2019 游记

    写在前面 其实冬令营之后就有一些想说的内容,由于心情原因没有写出来.PKUWC 失误频频,唯一可能还有点价值的就是 Day2T3 计算几何推了 76 分出来.NOIWC 更是无心再谈,感觉是被提答送走 ...

  9. 论文分享NO.3(by_xiaojian)

    论文分享第三期-2019.03.29 Fully convolutional networks for semantic segmentation,CVPR 2015,FCN 一.全连接层与全局平均池 ...

  10. 服务器端控件同html控件的区别

    ●ASP.NET中共有几种类型的控件? 三种:1-asp.net控件(动态) 2-标准的html控件(静态) 3-标准的html控件加runat="server"属性(动态) 动态 ...