连接池

1)传统方式找DriverManager要连接。数目是有限的。

2)传统方式的close()。并没有将Connection重用。仅仅是切断应用程序和数据库的桥梁,即无发送到SQL命令到数据库端运行

3)项目中,对于Connection不说,不会直接使用DriverManager取得,而使用连接池方式。

4)DBCP和C3P0,都是Java开源的。都必须直接或间接实现javax.sql.DataSource接口

5)DBCP连接池须要dbcp.properties文件。同一时候需增加3个相应的jar包

*6)C3P0连接池须要在/WEB-INF/classes/文件夹下存放c3p0-config.xml文件,该类ComboPooledDataSource在创建时

会自己主动在指定的文件夹下找xml文件,并载入默认设置

7)重构JdbcUtil类

DBCP连接池

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

•        commons-dbcp.jar:连接池的实现

•        commons-pool.jar: 连接池实现的依赖类

•        commons-collections.jar :连接池实现的集合类

l      Tomcat 的连接池正是採用该连接池来实现的。

#dbcp.properties
配置文件

driverClassName=com.mysql.jdbc.Driver

url=jdbc:mysql://127.0.0.1:3306/mydb2

username=root

password=root

关键代码

static{

InputStreamin = JdbcUtil.class.getClassLoader().

getResourceAsStream("dbcp.properties");

Propertiesprop = new Properties();

prop.load(in);

BasicDataSourceFactoryfactory =
new BasicDataSourceFactory();

       dataSource = factory.createDataSource(prop);

}

实例代码:

//測试连接池DBCP的使用方法

publicclass Demo2 {

publicstaticvoid
main(String[] args) throws Exception {

long begin = System.currentTimeMillis();

//载入属性文件

InputStream is = Demo2.class.getClassLoader().getResourceAsStream("dbcp.properties");

Properties props =
new Properties();

props.load(is);

//创建DBCP连接池工厂

BasicDataSourceFactory factory =
new BasicDataSourceFactory();

//创建数据源,即连接池

DataSource ds =
factory.createDataSource(props);

for(int
i=1;i<=50000;i++){

//从连接池中取得一个空暇的连接对象

Connection conn = ds.getConnection();

if(conn!=null){

System.out.println(i+":取得连接");

}

//将连接对象还回给连接池

conn.close();

}

long end = System.currentTimeMillis();

System.out.println("共用"
+ (end-begin)/1000+"秒");

}

}

c3p0:

配置文件:

<?

xml
version="1.0"encoding="UTF-8"?>

<!-- 文件名称不能乱改,须用默认的c3o0-config.xml -->

<c3p0-config>

<default-config>

<property
name="driverClass">com.mysql.jdbc.Driver</property>

<property
name="user">root</property>

<property
name="password">root</property>

<property
name="jdbcUrl">jdbc:mysql://127.0.0.1:3306/mydb2</property>

</default-config>

</c3p0-config>

/推荐使用c3p0连接池

//測试连接池C3P0的使用方法

publicclass Demo3 {

publicstaticvoid
main(String[] args) throws Exception {

long begin = System.currentTimeMillis();

//创建C3P0连接池

ComboPooledDataSource dataSource =
new ComboPooledDataSource();

for(int
i=1;i<=100000;i++){

Connection conn = dataSource.getConnection();

if(conn!=null){

System.out.println(i+":取得连接");

conn.close();

}

}

long end = System.currentTimeMillis();

System.out.println("共用"
+ (end-begin)/1000+"秒");

}

}

JdbcUtil工具类,封装从c3p0的连接池获取连接:

//JDBC工具类:关闭流和取得连接

publicfinalclass JdbcUtil3 {

//数据源

privatestatic ComboPooledDataSource
dataSource;

static{//静态块。读取c3p0默认配置文件

dataSource =
new ComboPooledDataSource();

}

//取得连接

publicstatic Connection getMySqlConnection()
throws SQLException{

return 
dataSource.getConnection();

}

//关闭连接

publicstaticvoid
close(Connection conn) throws SQLException{

if(conn!=null){

conn.close();

}

}

}

C3P0连接池详细參数说明例如以下:

c3p0-config>

  <default-config>

 <!--当连接池中的连接耗尽的时候c3p0一次同一时候获取的连接数。Default:3
-->

 <propertyname="acquireIncrement">3</property>

 

 <!--定义在从数据库获取新连接失败后反复尝试的次数。Default: 30 -->

 <property name="acquireRetryAttempts">30</property>

 

 <!--两次连接中间隔时间,单位毫秒。Default:1000 -->

 <property name="acquireRetryDelay">1000</property>

 

 <!--连接关闭时默认将全部未提交的操作回滚。Default:false -->

 <propertyname="autoCommitOnClose">false</property>

 

 <!--c3p0将建一张名为Test的空表,并使用其自带的查询语句进行測试。

假设定义了这个參数那么

  属性preferredTestQuery将被忽略。

你不能在这张Test表上进行不论什么操作,它将仅仅供c3p0測试

  使用。Default:null-->

 <propertyname="automaticTestTable">Test</property>

<!--获取连接失败将会引起全部等待连接池来获取连接的线程抛出异常。可是数据源仍有效

  保留。并在下次调用getConnection()的时候继续尝试获取连接。

假设设为true,那么在尝试

  获取连接失败后该数据源将申明已断开并永久关闭。Default: false-->

 <property name="breakAfterAcquireFailure">false</property>

<!--当连接池用完时client调用getConnection()后等待获取新连接的时间,超时后将抛出

  SQLException,如设为0则无限期等待。单位毫秒。

Default: 0 --> 

 <property name="checkoutTimeout">100</property>

<!--通过实现ConnectionTester或QueryConnectionTester的类来測试连接。类名需制定全路径。

Default: com.mchange.v2.c3p0.impl.DefaultConnectionTester-->

 <propertyname="connectionTesterClassName"></property>

<!--指定c3p0 libraries的路径,假设(通常都是这样)在本地就可以获得那么无需设置。默认null就可以

  Default: null-->

 <propertyname="factoryClassLocation">null</property>

<!--Stronglydisrecommended. Setting this to true may lead to subtle and bizarre bugs. 

  (文档原文)作者强烈建议不使用的一个属性--> 

 <propertyname="forceIgnoreUnresolvedTransactions">false</property>

<!--每60秒检查全部连接池中的空暇连接。Default:
0 --> 

 <property name="idleConnectionTestPeriod">60</property>

<!--初始化时获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default:
3 --> 

 <property name="initialPoolSize">3</property>

 

 <!--最大空暇时间,60秒内未使用则连接被丢弃。

若为0则永不丢弃。

Default:
0 -->

 <propertyname="maxIdleTime">60</property>

 

 <!--连接池中保留的最大连接数。Default:15 -->

 <property name="maxPoolSize">15</property>

 

 <!--JDBC的标准參数。用以控制数据源内载入的PreparedStatements数量。但因为预缓存的statements

  属于单个connection而不是整个连接池。

所以设置这个參数须要考虑到多方面的因素。

  假设maxStatements与maxStatementsPerConnection均为0。则缓存被关闭。Default:
0-->

 <property name="maxStatements">100</property>

 

 <!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。Default:
0  -->

 <propertyname="maxStatementsPerConnection"></property>

<!--c3p0是异步操作的,缓慢的JDBC操作通过帮助进程完毕。扩展这些操作能够有效的提升性能

  通过多线程实现多个操作同一时候被运行。

Default:3--> 

 <property name="numHelperThreads">3</property>

<!--当用户调用getConnection()时使root用户成为去获取连接的用户。

主要用于连接池连接非c3p0

  的数据源时。Default:null--> 

 <propertyname="overrideDefaultUser">root</property>

 

 <!--与overrideDefaultUser參数相应使用的一个參数。Default:null-->

 <property name="overrideDefaultPassword">password</property>

<!--password。Default: null--> 

 <property name="password"></property>

<!--定义全部连接測试都运行的測试语句。在使用连接測试的情况下这个一显著提高測试速度。

注意:

  測试的表必须在初始数据源的时候就存在。Default:null-->

 <propertyname="preferredTestQuery">select id from test whereid=1</property>

<!--用户改动系统配置參数运行前最多等待300秒。

Default:
300 --> 

 <property name="propertyCycle">300</property>

 

 <!--因性能消耗大请仅仅在须要的时候使用它。假设设为true那么在每一个connection提交的

  时候都将校验其有效性。建议使用idleConnectionTestPeriod或automaticTestTable

  等方法来提升连接測试的性能。

Default:false -->

 <propertyname="testConnectionOnCheckout">false</property>

 

 <!--假设设为true那么在取得连接的同一时候将校验连接的有效性。

Default:false
-->

 <propertyname="testConnectionOnCheckin">true</property>

<!--username。Default: null-->

 <propertyname="user">root</property>

<!--早期的c3p0版本号对JDBC接口採用动态反射代理。在早期版本号用途广泛的情况下这个參数

  同意用户恢复到动态反射代理以解决不稳定的故障。

最新的非反射代理更快而且已经開始

  广泛的被使用,所以这个參数未必实用。如今原先的动态反射与新的非反射代理同一时候受到

  支持,但今后可能的版本号可能不支持动态反射代理。Default: false-->

 <propertyname="usesTraditionalReflectiveProxies">false</property>

<property name="automaticTestTable">con_test</property>

    <propertyname="checkoutTimeout">30000</property>

    <propertyname="idleConnectionTestPeriod">30</property>

    <propertyname="initialPoolSize">10</property>

    <propertyname="maxIdleTime">30</property>

    <propertyname="maxPoolSize">25</property>

    <propertyname="minPoolSize">10</property>

    <propertyname="maxStatements">0</property>

<user-overrides user="swaldman">

    </user-overrides>

</default-config>

  <named-config name="dumbTestConfig">

    <propertyname="maxStatements">200</property>

    <user-overrides user="poop">

      <propertyname="maxStatements">300</property>

    </user-overrides>

   </named-config>

</c3p0-config>

JDBC连接池C3P0的更多相关文章

  1. JDBC连接池-C3P0连接

    JDBC连接池-C3P0连接 c3p0连接池的学习英语好的看英文原版      c3p0 - JDBC3 Connection and Statement Pooling 使用c3p0连接池  三种方 ...

  2. jdbc连接池c3p0/dbcp强制连接超过设置时间后失效

    通常来说,各种技术实现的优化参数或者选项或者歪门邪道之所以能被想出来,通常是因为开发者或者实现的贡献者曾经遇到过导致此结果的问题,所以才出了对应的策略选项. 在有些情况下,比如存在客户端或者服务端连接 ...

  3. JDBC连接池-C池3P0连接

    JDBC连接池-C3P0连接 c3p0连接池的学习英语好的看英文原版      c3p0 - JDBC3 Connection and Statement Pooling 使用c3p0连接池  三种方 ...

  4. 四大流行的jdbc连接池之C3P0篇

    C3P0是一个开放源代码的JDBC连接池,它在lib目录中与Hibernate一起发布,包括了实现jdbc3和jdbc2扩展规范说明的Connection 和Statement 池的DataSourc ...

  5. 网络协议 finally{ return问题 注入问题 jdbc注册驱动问题 PreparedStatement 连接池目的 1.2.1DBCP连接池 C3P0连接池 MYSQL两种方式进行实物管理 JDBC事务 DBUtils事务 ThreadLocal 事务特性 并发访问 隔离级别

    1.1.1 API详解:注册驱动 DriverManager.registerDriver(new com.mysql.jdbc.Driver());不建议使用 原因有2个: >导致驱动被注册2 ...

  6. Spring+SpringMVC+MyBatis+easyUI整合优化篇(九)数据层优化-jdbc连接池简述、druid简介

    日常啰嗦 终于回到既定轨道上了,这一篇讲讲数据库连接池的相关知识,线程池以后有机会再结合项目单独写篇文章(自己给自己挖坑,不知道什么时候能填上),从这一篇文章开始到本阶段结束的文章都会围绕数据库和da ...

  7. Java开源连接池c3p0的基本用法

    前言:其实c3p0只是一个实现了javax.sql 接口 DataSource的一个工具集,使用c3p0可以帮我们管理宝贵的Connection资源,无须我们去创建连接(免去每次配置数据库驱动,url ...

  8. JDBC连接池(三)DBCP连接池

    JDBC连接池(三)DBCP连接池 在前面的随笔中提到 了  1.JDBC自定义连接池  2. C3P0连接池 今天将介绍DBCP连接池 第一步要导入jar包   (注意:mysql和mysql 驱动 ...

  9. JDBC连接池-自定义连接池

    JDBC连接池 java JDBC连接中用到Connection   在每次对数据进行增删查改 都要 开启  .关闭  ,在实例开发项目中 ,浪费了很大的资源 ,以下是之前连接JDBC的案例 pack ...

随机推荐

  1. [POI2011]MET-Meteors(整体二分+树状数组)

    题意 给定一个环,每个节点有一个所属国家,k次事件,每次对[l,r]区间上的每个点点权加上一个值,求每个国家最早多少次操作之后所有点的点权和能达到一个值 题解 一个一个国家算会T.这题要用整体二分.我 ...

  2. cygwin下调用make出现的奇怪现象

    <lenovo@root 11:48:03> /cygdrive/d/liuhang/GitHub/rpi_linux/linux$make help 1 [main] make 4472 ...

  3. flash3D学习1

    今天正式学习flash3D. 先配置: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0 ...

  4. LINUX设备驱动程序笔记(一)设备驱动程序简单介绍

    <一>:设备驱动程序的作用 从一个角度看,设备驱动程序的作用在于提供机制,而不是策略. 在编写驱动程序时,程序猿应该特别注意以下这个基本概念:编写訪问硬件的内核代码时,不要给用户强加不论什 ...

  5. Java之——删除ArrayList中的反复元素的2种方法

    转载请注明出处:http://blog.csdn.net/l1028386804/article/details/47414935 ArrayList是Java中最经常使用的集合类型之中的一个.它同意 ...

  6. 在Unix上用 BIND建立名称服务器(naem server)

    在Unix上用 BIND建立名称服务器(naem server) 安装 apt install -y bind9 yum install -y bind bind-utils 下载源码并解压缩,htt ...

  7. Python正则表达式初识(二)

    前几天给大家分享了Python正则表达式初识(一),介绍了正则表达式中的三个特殊字符“^”.“.”和“*”,感兴趣的伙伴可以戳进去看看,今天小编继续给大家分享Python正则表达式相关特殊字符知识点. ...

  8. noip 2018 day1 T1 铺设道路 贪心

    Code: #include<cstdio> using namespace std; int main() { int last=0,ans=0; int n;scanf("% ...

  9. box-shadow制作各种单边,多边阴影

    一.box-shadow问题探究 box-shadow 在MDN定义以及详解: box-shadow 以由逗号分隔的列表来描述一个或多个阴影效果.该属性让你可以对几乎所有元素的边框产生阴影.如果元素同 ...

  10. 【Redis发布订阅】

    Redis通过PUBLISH.SUBSCRIBE等命令实现发布与订阅模式. 举例:QQ群的公告,单个发布者,多个收听着. *** 发布/订阅 PUBLISH 频道 消息 将消息发布到指定的频道. . ...