配置文件:jdbc.properties

username=root
password=kk
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://192.168.56.1:3306/test

initialSize=10
maxTotal=50
minIdle=5
maxWaitMillis=5000

测试文件:JDBCTest.java

import java.io.InputStream;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;
import javax.sql.DataSource;
import org.apache.commons.dbcp2.BasicDataSource;
import org.apache.commons.dbcp2.BasicDataSourceFactory;
import org.junit.Test;

public class JDBCTest {

  /*
    * 1、加载dbcp的properties配置文件:配置文件中的键需要来自BasicDataSource的属性
    * 2、调用BasicDataSourceFactory的createDataSource方法创建DataSource实例
    * 3、从DataSource获取数据库连接
    * */
   @Test
   public void testDBCPWithDataSourceFactory() throws Exception{
  
      Properties properties=new Properties();
      InputStream is=JDBCTest.class.getClassLoader().getResourceAsStream("jdbc.properties");
      properties.load(is);
      DataSource ds=BasicDataSourceFactory.createDataSource(properties);
      System.out.println(ds.getConnection());
      //验证配置文件的属性
      BasicDataSource basicDataSource=(BasicDataSource) ds;
      System.out.println("最大等待时间:"+basicDataSource.getMaxWaitMillis());
   }

  //还有一种不用通过配置文件的方式如下单元测试方法:

  /*
    * 使用DBCP数据库连接池
    * 1、加入jar包
    * 2、创建数据库连接池
    * 3、设置数据源必须的属性
    * 4、从数据源中获取数据库连接
    * */
   @Test
   public void testDBCP() throws SQLException{
  
      //1、创建DBCP数据源实例 
      final BasicDataSource bds=new BasicDataSource();
  
      //2、为数据源实例指定必须的属性
      bds.setUsername("root");
      bds.setPassword("kk");
      bds.setUrl("jdbc:mysql:///test");
      bds.setDriverClassName("com.mysql.jdbc.Driver");
      /*
       * 3、指定数据源一些可选的属性
       *  1>指定数据库连接池中初始化连接数
       *  2>指定最大的连接数:同一时刻可以同时向数据库申请的连接数
       *  3>指定最小连接数:在数据库连接池空闲状态下,连接池中最少有多少个连接
       * */
      bds.setInitialSize(10);
      bds.setMaxTotal(3);
      bds.setMinIdle(2);
      //获取连接时的最大等待毫秒数
      bds.setMaxWaitMillis(1000*5);
      //4、从数据源获取数据库连接
      Connection con=bds.getConnection();
      System.out.println("1---》"+con);
      Connection con2=bds.getConnection();
      System.out.println("2---》"+con2);
      Connection con3=bds.getConnection();
      System.out.println("3---》"+con3);
  
      new Thread(){
         public void run() {
            Connection conn;
            try {
               conn=bds.getConnection();
               System.out.println("thread->"+conn.getClass());
            } catch (Exception e) {
     
            }
         };
      }.start();
  
      try {
         Thread.sleep(3000);
      } catch (InterruptedException e) {
         e.printStackTrace();
      }
        con2.close();
   }
}

<十三>JDBC_dbcp数据库连接池的更多相关文章

  1. JavaWeb学习总结(十三)--数据库连接池

    一.数据库连接池的概念 用池来管理Connection,这可以重复使用Connection.有了池,所以我们就不用自己来创建Connection,而是通过池来获取Connection对象.当使用完Co ...

  2. Java第三方数据库连接池库-DBCP-C3P0-Tomcat内置连接池

    连接池原理 数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”.预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去.我们可以通过设定连接池 ...

  3. .数据库连接池技术:DBCP和C3P0

    数据库连接池技术:DBCP和C3P0 1.什么是数据库连接池 已知的方法是需要访问数据库的时候进行一次数据库的连接,对数据库操作完之后再释放这个连接,通常这样业务是缺点很明显的: 用户每次请求都需要向 ...

  4. [转]阿里巴巴数据库连接池 druid配置详解

    一.背景 java程序很大一部分要操作数据库,为了提高性能操作数据库的时候,又不得不使用数据库连接池.数据库连接池有很多选择,c3p.dhcp.proxool等,druid作为一名后起之秀,凭借其出色 ...

  5. 数据库连接池c3p0学习

    这里只记录c3p0的数据源,不会涉及到其它方面和别的数据库连接池的对比 配置文件主要的实现方式有三种: 1.手写代码去加载一个配置文件 创建一个config.properties文件如下: drive ...

  6. <十四>JDBC_c3p0数据库连接池

    配置文件:c3p0-config.xml <!-- Hibernate官方推荐使用的数据库连接池即c3p0;dbcp是Tomcat在数据源中使用 --><c3p0-config> ...

  7. c3p0数据库连接池的使用详解

    首先,什么是c3p0?下面是百度百科的解释: C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展.目前使用它的开源项目有Hibernate,Sp ...

  8. Mybatis-update - 数据库死锁 - 获取数据库连接池等待

    最近学习测试mybatis,单个增删改查都没问题,最后使用mvn test的时候发现了几个问题: update失败,原因是数据库死锁 select等待,原因是connection连接池被用光了,需要等 ...

  9. 从零开始学 Java - 数据库连接池的选择 Druid

    我先说说数据库连接 数据库大家都不陌生,从名字就能看出来它是「存放数据的仓库」,那我们怎么去「仓库」取东西呢?当然需要钥匙啦!这就是我们的数据库用户名.密码了,然后我们就可以打开门去任意的存取东西了. ...

随机推荐

  1. url带#号,微信支付那些坑

    现在前端很多框架的前端路由都带#号,主要为了做到无刷新跳转页面. 在微信公众号做微信支付时,配置的支付路径比如是http://www.eee.com/#/order,在调微信支付的方法时错误信息是'U ...

  2. 史上最全的maven的pom.xml文件详解

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  3. jsonp是什么【转载自JavaScript微信公众号】

    转自 http://mp.weixin.qq.com/s/xNnKAeLv6sO0T-IvP2AUlQ          JavaScript微信公众号 一.JSONP的诞生 首先,因为ajax无法跨 ...

  4. php定界符<<<EOF讲解(转)

    Heredoc技术.可用来输出大段的html和javascript脚本 1.PHP定界符的作用就是按照原样,包括换行格式什么的,输出在其内部的东西: 2.在PHP定界符中的任何特殊字符都不需要转义:  ...

  5. C#事件的理解应用

    之前对C#的事件理解的不够透彻,总是感觉在实际应用上差一些火候.最近写character类的相关内容,有了一些理解,在这里分享一下. &感觉大神没必要往下看了 下面开始正式内容: 比如说,角色 ...

  6. linux学习日记之目录配制

    linux目录管理遵循FHS标准,主要目标是希望让使用者可以了解已安装软件通常放置于哪个目录上,所以他们希望独立的软件开发商.操作系统制作者.以及想要维护系统的用户,都遵循FHS的标准.也就是说FHS ...

  7. Python中的网络编程

    TCPServer端: __author__ = 'Nature' # -*- coding: utf-8 -*- from socket import * from time import ctim ...

  8. 判断是否为gif/png图片的正确姿势

    判断是否为gif/png图片的正确姿势 1.在能取到图片后缀的前提下 1 2 3 4 5 6 7 8 9 //假设这是一个网络获取的URL NSString *path = @"http:/ ...

  9. 使用Solr索引MySQL数据

    环境搭建 1.到apache下载solr,地址:http://mirrors.hust.edu.cn/apache/lucene/solr/ 2.解压到某个目录 3.cd into D:\Solr\s ...

  10. linux内核(kernel)版本号的意义

    转自:http://www.cnblogs.com/jsjliuxing/archive/2011/12/01/2271182.html 在linux下有一个目录,即/usr/src/kernels/ ...