活动地址: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);
}
}