网站首页 > 开源技术 正文
一.数据库连接池的必要性
(一).传统数据库连接模式的的步骤
1.在主程序中创建连接
2.进行sql操作
3.关闭数据库连接
(二).传统数据库连接模式存在的问题
1.浪费时间:每次连接时都要验证登录和将conn加载到内存,
2.不能大规模的访问数据库:当数据库访问人数过多时,占用大量系统资源,会导致服务器崩溃
3.存在内存泄漏问题:每次连接都需要断开连接,如果不断开,程序运行结束,会有创建的连接对象存在内存中一直无法关闭,就会导致java内存泄漏的问题。
内存泄漏:指创建的对象无法被回收
二.数据库连接池技术
(一).数据连接池的思想:
事先在内存中建立一个缓冲池,用来存放一定数量的连接对象,需要时在里面调用,结束时放回缓冲池。
(二).数据库连接池的任务:
管理和释放数据库连接,允许用户使用池内的连接对象,而不需要创建对象。
(三).数据库连接池的规模:
初始化时的数量:由数据库最小连接数来设定;
最大数量:由最大数据库连接数来确定。
当连接数超过了最大连接数,超过的连接就会停止等待连接对象的释放。
(四).工作原理:
(五).数据库连接池的优点:
1.资源重用:
连接池中的对象需要时取出,不需要被连接池回收
2.更快的反应速度:
事先在池中储备连接对象,初始化已经完成,直接调用。
3.数据库共享机制
多个用户访问同一数据库,通过在应用层的配置,可以避免资源独占。
4.避免内存泄漏:
连接对象统一管理,设置连接对象时间片,超时强制回收。
三.多种开源的数据库连接池
JDBC的数据库连接池使用javax.sql.DataSource来表示,DataSource是一个接口,该接口通常由服务器提供。
(一).常见的开源数据库连接池:
DBCP:速度比C3P0快但有bug
c3p0:速度慢,但相对稳定
Proxool:开源连接池,有监控连接池的功能,但稳定性比C3P0差
BoneCP:速度快,开源
Druid:阿里提供的连接池,速度快(不及BoneCP),稳定性好,有监控连接池的功能。
四.学习最主流的数据库连接池Druid
(一).为druid数据库连接池创建properties文件
driverClassName=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/jdbc_db
username=root
password=3.141592654
initialSize=10
maxActive=20
(二).创建数据库连接池
public Class JDBCUtils{
private static DataSource source;
static {
try{
//创建properties对象,用来封装从文件中获取的流数据
Properties pros = new Properties();
//采用类加载方式获取文件的内容,并封装成流
InputStream is = ClassLoader.getSystemClassLoader().getResourceAsStream("Druid.properties");
//将流传入到pros对象中
pros.load(is);
//利用工厂类创建数据库连接池
source = DruidDataSourceFactory.createDataSource(pros);
}catch (Exception e){
e.printStackTrace();
}
}
public static Connection getConnByDruid() throws Exception {
//所有的数据连接池要想被java所使用,都必须先实现sun公司提供的一个接口DateSource
//获取数据库连接池对象
Connection conn = source.getConnection();
return conn;
}
}
(三).测试通过数据库连接池获取连接对象
public class TestDruid {
@Test
public void getDruidConn() throws Exception {
Properties pros = new Properties();
InputStream is = ClassLoader.getSystemClassLoader().getResourceAsStream("Druid.properties");
pros.load(is);
//所有的数据连接池要想被java所使用,都必须先实现sun公司提供的一个接口DateSource
//获取数据库连接池对象
DataSource source = DruidDataSourceFactory.createDataSource(pros);
Connection conn = source.getConnection();
System.out.println(conn);
}
}
(四).测试结果(创建成功)
五.Druid数据库连接池常见配置参数
猜你喜欢
- 2025-01-07 几个简单法则,让春装更“出色”
- 2025-01-07 BF仔裤要穿的帅 但是不要真的穿成蓝朋友!
- 2025-01-07 正畸治疗后的牙间黑三角
- 2025-01-07 解放双脚 从一双Espadrilles渔夫鞋开始
- 2025-01-07 自古红蓝出CP 其实还能加一点黑&白!
- 2025-01-07 呦呦呦,杨幂用连帽衫加棒球帽好时髦,开春我要变酷酷“少女风”
- 2025-01-07 穿搭套路深 总是有新CP能给你惊喜!
- 2025-01-07 路医生说|急性跟腱断裂要不要手术,如何更快康复?
- 2025-01-07 MyBatis整合Springboot多数据源实现
- 2025-01-07 sharding-jdbc分库分表及读写分离
你 发表评论:
欢迎- 05-16东契奇:DFS训练时喷了我很多垃圾话 我不懂他为什么比赛不这么干
- 05-16这两球很伤!詹姆斯空篮拉杆不中 DFS接里夫斯传球空接也没放进
- 05-16湖人自媒体调查:89%球迷希望DFS回归79%希望詹姆斯回归
- 05-16Shams:湖人得到全能球员DFS 节省了1500万奢侈税&薪金空间更灵活
- 05-16G5湖人胜率更高!詹姆斯不满判罚,DFS谈5人打满下半场:这很艰难
- 05-16DFS:当东契奇进入状态 所有防守者在他面前都像个圆锥桶
- 05-16上一场9中6!DFS:不能让纳兹-里德这样的球员那么轻松地投三分
- 05-16WIDER FACE评测结果出炉:滴滴人脸检测DFS算法获世界第一
- 最近发表
-
- 东契奇:DFS训练时喷了我很多垃圾话 我不懂他为什么比赛不这么干
- 这两球很伤!詹姆斯空篮拉杆不中 DFS接里夫斯传球空接也没放进
- 湖人自媒体调查:89%球迷希望DFS回归79%希望詹姆斯回归
- Shams:湖人得到全能球员DFS 节省了1500万奢侈税&薪金空间更灵活
- G5湖人胜率更高!詹姆斯不满判罚,DFS谈5人打满下半场:这很艰难
- DFS:当东契奇进入状态 所有防守者在他面前都像个圆锥桶
- 上一场9中6!DFS:不能让纳兹-里德这样的球员那么轻松地投三分
- WIDER FACE评测结果出炉:滴滴人脸检测DFS算法获世界第一
- 湖人自媒体调查:89%球迷希望DFS回归 79%希望詹姆斯回归
- 一觉醒来湖人苦盼的纯3D终于到位 DFS能带给紫金军多少帮助
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)