1.传统链接(如下为示意图)

注意:

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

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

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

2.采用连接池(示意图)

3.开源数据库连接池

(1).现在很多Web服务器(Weblogic, WebSphere, Tomcat)都提供了DataSoruce的实现,即连接池的实现。通常我们把DataSource的实现,按其英文含义称之为数据源,数据源中都包含了数据库连接池的实现。
(2).也有一些开源组织提供了数据源的独立实现:
DBCP 数据库连接池(tomcat)
C3P0 数据库连接池(hibernate)
(3).实际应用时不需要编写连接数据库代码,直接从数据源获得数据库的连接。程序员编程时也应尽量使用这些数据源的实现,以提升程序的数据库访问性能。

4.C3P0的使用:
(1).在classpath的路径下配置xml文件,即src的文件下而且这个文件名必须是c3p0-config.xml

原始的c3p0-config.xml的文件参数:

<c3p0-config><default-config><!-- 当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 --><property name="acquireIncrement">3</property><!-- 定义在从数据库获取新连接失败后重复尝试的次数。Default: 30 --><property name="acquireRetryAttempts">30</property><!-- 两次连接中间隔时间,单位毫秒。Default: 1000 --><property name="acquireRetryDelay">1000</property><!-- 连接关闭时默认将所有未提交的操作回滚。Default: false --><property name="autoCommitOnClose">false</property><!--c3p0将建一张名为Test的空表,并使用其自带的查询语句进行测试。如果定义了这个参数那么属性preferredTestQuery将被忽略。你不能在这张Test表上进行任何操作,它将只供c3p0测试 使用。Default:null--><property name="automaticTestTable">Test</property><!--获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常。但是数据源仍有效保留,并在下次调用getConnection()的时候继续尝试获取连接。如果设为true,那么在尝试获取连接失败后该数据源将申明已断开并永久关闭。Default: false--><property name="breakAfterAcquireFailure">false</property><!--当连接池用完时客户端调用getConnection()后等待获取新连接的时间,超时后将抛出SQLException,如设为0则无限期等待。单位毫秒。Default: 0--><property name="checkoutTimeout">100</property><!--通过实现ConnectionTester或QueryConnectionTester的类来测试连接。类名需制定全路径。 Default:com.mchange.v2.c3p0.impl.DefaultConnectionTester--><property name="connectionTesterClassName"></property><!--指定c3p0 libraries的路径,如果(通常都是这样)在本地即可获得那么无需设置,默认null即可 Default: null--><property name="factoryClassLocation">null</property><!--Strongly disrecommended. Setting this to true may lead to subtle andbizarre bugs. (文档原文)作者强烈建议不使用的一个属性--><property name="forceIgnoreUnresolvedTransactions">false</property><!-- 每60秒检查所有连接池中的空闲连接。Default: 0 --><property name="idleConnectionTestPeriod">60</property><!-- 初始化时获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default: 3 --><property name="initialPoolSize">3</property><!-- 最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 --><property name="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--><property name="maxStatementsPerConnection"></property><!--c3p0是异步操作的,缓慢的JDBC操作通过帮助进程完成。扩展这些操作可以有效的提升性能通过多线程实现多个操作同时被执行。Default: 3--><property name="numHelperThreads">3</property><!--当用户调用getConnection()时使root用户成为去获取连接的用户。主要用于连接池连接非c3p0 的数据源时。Default:null--><property name="overrideDefaultUser">root</property><!-- 与overrideDefaultUser参数对应使用的一个参数。Default: null--><property name="overrideDefaultPassword">password</property><!-- 密码。Default: null--><property name="password"></property><!--定义所有连接测试都执行的测试语句。在使用连接测试的情况下这个一显著提高测试速度。注意:测试的表必须在初始数据源的时候就存在。Default: null--><property name="preferredTestQuery">select id from test where id=1</property><!-- 用户修改系统配置参数执行前最多等待300秒。Default: 300 --><property name="propertyCycle">300</property><!--因性能消耗大请只在需要的时候使用它。如果设为true那么在每个connection提交的时候都将校验其有效性。建议使用idleConnectionTestPeriod或automaticTestTable等方法来提升连接测试的性能。Default: false--><property name="testConnectionOnCheckout">false</property><!-- 如果设为true那么在取得连接的同时将校验连接的有效性。Default: false --><property name="testConnectionOnCheckin">true</property><!-- 用户名。Default: null--><property name="user">root</property><!--早期的c3p0版本对JDBC接口采用动态反射代理。在早期版本用途广泛的情况下这个参数允许用户恢复到动态反射代理以解决不稳定的故障。最新的非反射代理更快并且已经开始广泛的被使用,所以这个参数未必有用。现在原先的动态反射与新的非反射代理同时受到支持,但今后可能的版本可能不支持动态反射代理。Default:false。--><property name="usesTraditionalReflectiveProxies">false</property><property name="automaticTestTable">con_test</property><property name="checkoutTimeout">30000</property><property name="idleConnectionTestPeriod">30</property><property name="initialPoolSize">10</property><property name="maxIdleTime">30</property><property name="maxPoolSize">25</property><property name="minPoolSize">10</property><property name="maxStatements">0</property><user-overrides user="swaldman"></user-overrides></default-config><named-config name="dumbTestConfig"><property name="maxStatements">200</property><user-overrides user="poop"><property name="maxStatements">300</property></user-overrides></named-config>
</c3p0-config>

实战练习:
1>.首先配置c3p0-config.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<c3p0-config><default-config><property name="driverClass">com.mysql.jdbc.Driver</property><property name="user">root</property><property name="password">wwh</property><property name="jdbcUrl">jdbc:mysql://127.0.0.1:3306/jdbctest</property></default-config>
</c3p0-config>

2>.代码操作连接(TestC3P0.java)

package cn.wwh.www.java.jdbc.datasource;import java.sql.Connection;import com.mchange.v2.c3p0.ComboPooledDataSource;/***类的作用:***@author 一叶扁舟*@version 1.0*@创建时间: 2014-9-2   上午12:02:13*///测试连接池C3P0的用法
public class TestC3P0 {public static void main(String[] args) throws Exception {long begin = System.currentTimeMillis();//创建C3P0连接池,并加载c3p0-config.xml文件ComboPooledDataSource dataSource = new ComboPooledDataSource();for(int i=1;i<=1000000;i++){Connection conn = dataSource.getConnection();if(conn!=null){System.out.println("获取连接第"+i+"个");conn.close();}}long end = System.currentTimeMillis();System.out.println("用了" + (end-begin)/1000+"秒");}
}

5.DBCP的使用:
(1).采用类加载的方式,文件名是:dbcp.properties

driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/jdbctest
username=root
password=wwh

(2).在代码中使用(TestDBCP.java)

package cn.wwh.www.java.jdbc.datasource;import java.io.InputStream;
import java.sql.Connection;
import java.util.Properties;import javax.sql.DataSource;import org.apache.commons.dbcp.BasicDataSourceFactory;/***类的作用:采用DBCP连接池的方式去获取数据库的链接,并测试他的时间***@author 一叶扁舟*@version 1.0*@创建时间: 2014-9-1   下午09:27:59*///测试连接池DBCP的用法
public class TestDBCP {public static void main(String[] args) throws Exception {long begin = System.currentTimeMillis();//加载属性文件InputStream is = TestDBCP.class.getClassLoader().getResourceAsStream("cn/wwh/www/java/jdbc/config/dbcp.properties");Properties props = new Properties();props.load(is);//创建DBCP连接池工厂BasicDataSourceFactory factory = new BasicDataSourceFactory(); //创建数据源,即连接池DataSource ds = factory.createDataSource(props);for(int i=1;i<=1000000;i++){//从连接池中取得一个空闲的连接对象Connection conn = ds.getConnection();if(conn!=null){System.out.println("获取连接第"+i+"个");}//将连接对象还回给连接池conn.close();}long end = System.currentTimeMillis();System.out.println("用了" + (end-begin)/1000+"秒");}
}

第一的测试时间为18秒,第二个的测试时间为13秒,不同的机器性能不一样,测试的时间快慢也不可能。但是理论上C3P0的速度应该更快,但是我测试的数据却恰恰相反,很是奇怪。

总结:

1>DBCP和C3P0,都是Java开源的,都必须直接或间接实现javax.sql.DataSource接口
2>DBCP连接池需要dbcp.properties文件,同时需加入3个对应的jar包
3>C3P0连接池需要在/WEB-INF/classes/目录下存放c3p0-config.xml文件,该类ComboPooledDataSource在创建时
会自动在指定的目录下找xml文件,并加载默认设置

4>tomcat用的也是c3p0

6.导入的jar包

commons-dbcp.jar:DBCP实现要导入的jar

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

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

c3p0-0.9.1.2.jar :C3P0实现要导入的jar包

来源:https://www.2cto.com/database/201409/330612.html

MySql数据库连接池相关推荐

  1. Tomcat 5.5 配置 MySQL 数据库连接池

    用了最新的几个咚咚,搞了整整一天终于搞清楚了Tomcat 5.5 配置 MySQL 数据库连接池,网上的经验并不能完全用到新环境里面,我写出整个过程以方便大家配置. 1 环境描述 JDK 1.5 To ...

  2. python实现数据库连接池_Python实现Mysql数据库连接池

    Python实现Mysql数据库连接池 python连接Mysql数据库: python编程中可以使用MySQLdb进行数据库的连接及诸如查询/插入/更新等操作,但是每次连接mysql数据库请求时,都 ...

  3. tomcat7.0.42如何设置mysql数据库连接池

    转载自   tomcat7.0.42如何设置mysql数据库连接池 如何在tomcat7.0.42中设置mysql数据库连接池????eclipse如何绑定tomcat??按网上教程总不成功!怎么办 ...

  4. jboss mysql cluster_jboss配置mysql数据库连接池

    jboss配置mysql数据库连接池 下面YJBYS小编为大家整理了关于jboss配置mysql数据库连接池的文章,希望对你有所帮助.更多Java认证考试信息,尽在应届毕业生培训网! 1:配置: JD ...

  5. Python操作数据库及Python实现mysql数据库连接池源代码

    简介 pymysql:纯Python实现的一个驱动.因为是纯Python编写的,因此执行效率不如MySQL-python.并且也因为是纯Python编写的,因此可以和Python代码无缝衔接. MyS ...

  6. Node.js实现MySQL数据库连接池

    Node.js实现MySQL数据库连接池 1 什么是数据库连接池 2 原理及优点 3 连接池的作用 4 实现连接池 4.1 导入mysql模块 4.2 创建数据库连接池 4.3 从连接池中获取一个连接 ...

  7. Tomcat中配置MySQL数据库连接池

    Web开发中与数据库的连接是必不可少的,而数据库连接池技术很好的优化了动态页与数据库的连接,相比单个连接数据库连接池节省了很大的资源.用一个通俗的比喻:如果一个人洗澡需花一桶水,那一百个人就要花一百桶 ...

  8. mysql数据库连接池_MySql数据库连接池

    1.传统链接(如下为示意图) 注意: (1).传统方式找DriverManager要连接,数目是有限的. (2).传统方式的close(),并没有将Connection重用,只是切断应用程序和数据库的 ...

  9. java连接mysql数据库连接池_java使用原生MySQL实现数据的增删改查以及数据库连接池技术...

    一.工具类及配置文件准备工作 1.1 引入jar包 使用原生MySQL,只需要用到MySQL连接的jar包,maven引用方式如下: mysql mysql-connector-java 5.1.48 ...

最新文章

  1. Swift - 使用SwiftHTTP通过HTTPS进行网络请求,及证书的使用
  2. python windows控制台,如何从python启用Windows控制台快速编辑模式?
  3. (转)android四种动画
  4. Linux的system和popen的差异
  5. 静态时序分析——On-chip Variation
  6. execve系统调用_张凯捷—系统调用分析(3) (基于最新Linux5.0版本系统调用日志收集系统)...
  7. Transfomer入门:Self-attention + Multi-head Self-attention
  8. windows开启ping功能
  9. 从入门到精通:卷积神经网络初学者指南
  10. uni-app 获取手机状态栏高度
  11. 流程图软件用哪款: Draw.io, 亿图图示, ProcessOn. 做最适合你的流程图
  12. OWASP Top 10 2017 10项最严重的 Web 应用程序安全风险
  13. 其他计算机才能打印,关于HPM126A打印机共享问题-共享之后主机得打印一次后其他电脑才能打印...
  14. 微信支付提示:支付失败,如果已经扣款,资金会在0~3个工作日内原路退回
  15. Excel单元格区域快速导出为PDF
  16. CSS hover改变背景图片过渡动画生硬
  17. 数据结构-排序算法总结与感悟
  18. 边坡裂缝拉绳位移计的原理及怎样进行长期健康监测
  19. 车轮轨迹原理_在简单地形上小车运动轨迹的数学表达(一)
  20. 学习xpath解析用的代码

热门文章

  1. 客户服务器结构的数据库系统,客户服务器结构的数据库的例子
  2. 46栈内存溢出、内存区域(程序计数器、Java 虚拟机栈、本地方法栈、Java 堆、方法区、直接内存、内存溢出)与内存溢出(对象实例化分析)
  3. 通过源码的方式编译hadoop的安装文件
  4. 1.关于UltraEdit中的FTP和Tenent配置,UE远程连接Linux进行文件操作
  5. Nginx+Tomcat负载均衡配置
  6. 吃豆豆游戏的C语言程序码,C++实现基于控制台界面的吃豆子游戏
  7. 实现哈希表 java,如何实现Java的哈希表?
  8. chrome插件infinity_5款超好用Chrome插件,快试试看!
  9. 深入浅出设计模式原则之单一原则(SRP)
  10. 使用webpack打包vue工程