MySql数据库连接池

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 and
			bizarre 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包

时间: 2024-08-11 03:31:01

MySql数据库连接池的相关文章

Python实现Mysql数据库连接池

python连接Mysql数据库: Python编程中可以使用MySQLdb进行数据库的连接及诸如查询/插入/更新等操作,但是每次连接MySQL数据库请求时,都是独立的去请求访问,相当浪费资源,而且访问数量达到一定数量时,对mysql的性能会产生较大的影响.因此,实际使用中,通常会使用数据库的连接池技术,来访问数据库达到资源复用的目的. python的数据库连接池包 DBUtils: DBUtils是一套Python数据库连接池包,并允许对非线程安全的数据库接口进行线程安全包装.DBUtils来

Java-自定义简单的mysql数据库连接池

   当我们在使用java连接数据库的时候,要注册驱动,.再通过"驱动管理器"获取连接对象(Connection),当我们的程序被很多用户访问的时候,每次都创建一个Connection连接对 象的时候,程序会变得特别卡,这时候我们可以通过数据库连接池来解决这个问题. 用连接池来管理Connection,这可以重复使用Connection.有了池,所以我们就不用自己来创建Connection,而是通过池来获取Connection对象.当使用完Connection后,调 用Connecti

MySql 数据库连接池

最近发布的一个项目总是无缘无故的断线,在IIS机器上直接浏览也不会出现黄页面,就是一直加载,最后断线. 重启IIS后恢复正常. 经过几次后,查看了IIS日志和WINDOWS日志,在WINDOWS日志中发现错误信息如下: <Data>error connecting: Timeout expired. The timeout period elapsed prior to obtaining a connection from the pool. This may have occurred b

Mysql数据库连接池知识分享

使用优点: 连接池最大的优点是性能.创建一个新的数据库连接是一个耗时耗资源的一个过程.而使用了连接池之后,连接请求可以直接通过连接池来提供而不需要重新连接.认证.这样就节省了时间. 使用缺点: 连接池中可能会存在着多个没有被使用一直连接着的数据库,这意味着资源的浪费. 基本原理: 连接池基本的思想是在系统初始化的时候,将数据库连接作为对象存储在内存中,当用户调用数据库操作类MySqlConnection的Open()方法时,并非建立一个新的连接,而是从连接池中取出一个已建立的空闲连接对象.使用完

C#数据库连接池 MySql SqlServer

查阅了一天的资料来学习MySql数据库连接池,终于在一遍博文上找到了,自己也整理了一下,希望对大家有用处 1. 建立线程池 1 using MySql.Data.MySqlClient; 2 using System; 3 using System.Collections; 4 using System.Collections.Generic; 5 using System.Linq; 6 using System.Text; 7 using System.Threading.Tasks; 8

项目经验——jboss 配置数据库连接池

数据库的连接和关闭是非常消耗系统资源的,在多层结构的应用环境中,这种资源消耗又直接的反映到系统性能上来.在项目实际应用中,最常用的解决方案便是建立数据库连接池. 一.数据库连接池基本原理 当程序启动时,系统主动建立出足够的数据库连接,并将这些连接组成一个连接池.每次应用程序请求数据库连接时,无需重新建立,直接从链接池中获取已建立连接.使用完毕后,无需关闭,直接归还给数据库连接池,以备其他程序调用.通过连接池,大大提高了程序运行效率. 二 .数据库连接池常用参数 连接池初始连接数 连接池最大连接数

Swoole MySQL 连接池的实现

目录 概述 代码 扩展 小结 概述 这是关于 Swoole 入门学习的第八篇文章:Swoole MySQL 连接池的实现. 第七篇:Swoole RPC 的实现 第六篇:Swoole 整合成一个小框架 第五篇:Swoole 多协议 多端口 的应用 第四篇:Swoole HTTP 的应用 第三篇:Swoole WebSocket 的应用 第二篇:Swoole Task 的应用 第一篇:Swoole Timer 的应用 收到读者的咨询,这情况大家可能也会有,所以就在这说说: "亮哥,我今年30岁了,

Java EE 基本开发流程及数据库连接池 Druid

一. 公司开发基本流程    a. 了解需求信息(比较模糊)        需求,不是别人告诉你的,是你自己挖掘出来的.        售前工程师(对行业知识了解):编程学不好,但懂点代码,对人的综合能力要求比较高 b. 产品经理:        整理需求,了解,从网上找些竞品分析.[3,5 个同类产品]        竞品分析:            1. 客户人群(流量)            2. 市场前景            3. 功能(优劣势) c. 产品设计师:          

Myeclipse WEB工程JSP使用JNDI 数据库连接池连接Mysql数据库

在网上查了很多,最后实现了.下面写一下过程: 首先,在WEBROOT/META-INF下建一个文件context.xml,内容为: <?xml version="1.0" encoding="UTF-8"?> <Context> <Resource name="jdbc/ConnectionPool" auth="Application" type="javax.sql.DataSour