数据库连接池简介
- 数据库连接池是个容器,负责分配、管理数据库连接(connection)
- 它允许应用程序重复使用一个现有的数据库连接,而不是再重新建立一个
- 释放空闲时间超过最大空闲时间的数据库连接来避免因为没有释放数据库连接而引起的数据库连接遗漏;
优点
- 连接资源复用
- 提升系统响应速度
- 避免数据库连接遗漏
连接池标准接口: DataSource
官方(SUN)提供数据库连接池标准接口,由第三方实现该接口
功能:获取连接 Connection getConnection();
常见的数据库连接池
DBCP
C3P0
Druid
- Druid连接池是阿里开源的DB连接池项目
- 功能强大、性能优秀,是Java最好的连接池之一
Druid数据库连接池
使用步骤
- 导入druid jar包
- 定义配置文件
- 加载配置文件
- 获取数据库连接池对象
- 获取连接
druid.properties配置文件设置
driverClassName=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://x.x.x.x:3306/test01?useSSL=false&serverTimezone=UTC
username=test01_rw
password=123456
#xxx
initialSize=5
#xxx
maxActive=10
#xxx
maxWait=3000
DruidDemo.java源代码
packagelocal.content.druid;
importcom.alibaba.druid.pool.DruidDataSourceFactory;
importjavax.sql.DataSource;
importjava.io.FileInputStream;
importjava.sql.Connection;
importjava.util.Properties;
publicclassDruidDemo{
publicstaticvoidmain(String[]args)throwsException{
//TODOAuto-generatedmethodstub
//导入druidjar包<dependency>
//定义配置文件../resources/druid.properties
//加载配置文件
Propertiesprop=newProperties();
prop.load(newFileInputStream("jdbc01/src/main/resources/druid.properties"));
//获取数据库连接池对象
DataSourcedataSource=DruidDataSourceFactory.createDataSource(prop);
//获取连接
//Connectionconn=dataSource.getConnection();
Connectionconn=dataSource.getConnection();
System.out.println(conn);
//打印当前路径
System.out.println(System.getProperty("user.dir"));
}
}