Bootstrap

数据库连接池


活动地址:CSDN21天学习挑战赛

1.数据库连接池

连接池技术的核心思想是:连接复用,通过建立一个数据库连接池以及一套连接使用、分配、管理策略,使得该连接池中的连接可以得到高效、安全的复用,避免了数据库连接频繁建立、关闭的开销(其实就是一个容器,存放数据库连接的容器)

2.常见的数据库连接池技术
它一般由数据库厂商实现,因此由很多种。

C3P0是一个开源的JDBC连接池,它实现了数据源与JNDI绑定,支持JDBC3规范和实现了JDBC2的标准扩展说明的Connection和Statement池的DataSources对象。使用时需要导入jar包:c3p0-0.9.5.2.jar和mchange-commons-java-0.2.12.jar

Druid连接池是阿里巴巴开源的数据库连接池项目,后来贡献给Apache开源;Druid的作用是负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是再重新建立一个;
Druid连接池内置强大的监控功能,其中的StatFilter功能,能采集非常完备的连接池执行信息,方便进行监控,而监控特性不影响性能。
Druid连接池内置了一个监控页面,提供了非常完备的监控信息,可以快速诊断系统的瓶颈。使用时也需要导入jar包

3.C3P0使用
在导入jar包后,还需要定义配置文件(c3p0.properties或c3p0-config.xml)
c3p0-config.xml:

<c3p0-config>
  <!-- 使用默认的配置读取连接池对象 -->
  <default-config>
  	<!--  连接参数 -->
    <property name="driverClass">com.mysql.jdbc.Driver</property>
    <property name="jdbcUrl">jdbc:mysql://localhost:3306/db</property>
    <property name="user">root</property>
    <property name="password">root</property>
    
    <!-- 连接池参数 -->
    
    <!-- 初始化容器数量 -->
    <property name="initialPoolSize">5</property>
    <!-- 最大容器数量 -->
    <property name="maxPoolSize">10</property>
    <!-- 报错超时时间 -->
    <property name="checkoutTimeout">3000</property>
  </default-config>

  <named-config name="otherc3p0"> 
    <!--  连接参数 -->
    <property name="driverClass">com.mysql.jdbc.Driver</property>
    <property name="jdbcUrl">jdbc:mysql://localhost:3306/day25</property>
    <property name="user">root</property>
    <property name="password">root</property>
    
    <!-- 连接池参数 -->
    <property name="initialPoolSize">5</property>
    <property name="maxPoolSize">8</property>
    <property name="checkoutTimeout">1000</property>
  </named-config>
</c3p0-config>

实现:

public class c3p0Demo1 {
    public static void main(String[] args) {
        //创建连接池对象
        DataSource ds=new ComboPooledDataSource();//该配置文件自动加载,必须放在src目录下
        Connection con=null;
        //获取连接对象
        try {
            con= ds.getConnection();
            System.out.println(con);
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

4.Druid使用
配置文件为properties形式的,可以放在任意目录下
druid.properties:

driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/db
username=root
password=root
initialSize=5
maxActive=10
maxWait=3000

实现:

public class DruidDemo1 {
    public static void main(String[] args) throws Exception {
        //1.导入jar包
        //2.定义配置文件 druid.properties
        //3.加载配置文件
        Properties pro=new Properties();
        InputStream is = DruidDemo1.class.getClassLoader().getResourceAsStream("druid.properties");
        pro.load(is);
        //4.获得连接池对象
        DataSource ds = DruidDataSourceFactory.createDataSource(pro);
        //5.获取连接
        Connection con = ds.getConnection();
        System.out.println(con);

    }
}

;