mysql数据库连接池锁_MySql数据库连接池

本文介绍了数据库连接池的概念,对比了传统连接方式与连接池的区别,并详细讲解了C3P0和DBCP两种开源数据库连接池的配置与使用方法。通过示例代码展示了如何从数据源获取数据库连接,以及关闭连接以释放资源。最后总结了两种连接池的特性与区别。
摘要由CSDN通过智能技术生成

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

c181496042f5cc73a22372118b9d3d50.png

注意:

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

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

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

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

6556a3ebfb0e22dab5c447f83398ae62.png

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的文件参数:

3

30

1000

false

Test

false

100

null

false

60

3

60

15

100

3

root

password

select id from test where id=1

300

false

true

root

false

con_test

30000

30

10

30

25

10

0

200

300

实战练习:

1>.首先配置c3p0-config.xml文件

com.mysql.jdbc.Driver

root

wwh

jdbc:mysql://127.0.0.1:3306/jdbctest

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包

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值