理解数据库连接池底层原理之手写实现

简介:

前言

数据库连接池的基本思想是:为数据库连接建立一个“缓冲池”,预先在池中放入一定数量的数据库连接管道,需要时,从池子中取出管道进行使用,操作完毕后,在将管道放入池子中,从而避免了频繁的向数据库申请资源,释放资源带来的性能损耗。在如今的分布式系统当中,系统的QPS瓶颈往往就在数据库,所以理解数据库连接池底层构造原理与设计思想是很有益处的。我们常用的数据库连接池有C3P0,DBCP,Druid等,下面我们就来分析下数据库连接池应该有些什么,以及手写一个迷你版的数据库连接池!

对数据库连接池的一点思考

理解数据库连接池底层原理之手写实现

第一,数据库连接池中存放的就是数据库操作管道,不仅仅是存放,而且应该是管理这些管道;

第二,应该提供外部配置文件去初始化数据库连接池;

第三,如果一个数据库操作管道已经被占用,那么其他请求是否应该得到这个管道,也就是说我们要考虑多线程并发下,管道的分配问题;

第四,如果做到管道的复用?放回池子中,标示可用,并不是真正的关闭管道;

写一个迷你版数据库连接池

理解数据库连接池底层原理之手写实现

IMyPool是一个接口,对外提供数据库连接池的基本服务,比如得到一个数据库操作管道。

MyDefaultPool是IMyPool的实现。

MyPooledConnection代表数据库操作管道,它可以执行SQL,关闭管道等。

MyPoolFactory是一个工厂,单例模式,用于得到IMyPool实现。

DBConfigXML代表外部配置文件。

Test用于测试。

DBConfigXML

理解数据库连接池底层原理之手写实现

我们在实际中使用数据库连接池,需要在Spring的配置文件中,进行一些参数配置。这里,为了简化解析,直接提供。

MyPooledConnection

理解数据库连接池底层原理之手写实现

所谓数据库连接管道,就是对JDBC Connection进行封装而已,但是需要注意isBusy的这个标示。对管道的关闭,实际上只是标示的改变而已!

IMyPool

理解数据库连接池底层原理之手写实现

MyDefaultPool

理解数据库连接池底层原理之手写实现

需要注意到是,MyDefaultPool持有一个管道集合,基于多线程的考虑,这里使用了Vector。

MyDefaultPool需要初始化

理解数据库连接池底层原理之手写实现

数据库连接池需要根据外部配置文件完成数据库驱动加载以及初始化管道的建立。

createMyPooledConnection接口实现

理解数据库连接池底层原理之手写实现

数据库连接池在创建管道时,应该去看一下是否达到上限,如果没有,则可以创建。

不仅仅要创建出来,还要标示每一个管道的isBusy标志。

getMyPooledConnection接口实现

理解数据库连接池底层原理之手写实现

这里需要注意的是:如果得不到操作管道,需要去创建管道!

getRealConnectionFromPool

理解数据库连接池底层原理之手写实现

第一,这里使用了synchronized,就是为了避免多线程下产生问题。

第二,要知道Connection是有超时机制的,如果我们得到的管道的Connection已经超时了怎么办呢?

第三,得到管道后,一定注意isBusy的设置。

MyPoolFactory

理解数据库连接池底层原理之手写实现

Test测试

理解数据库连接池底层原理之手写实现

运行结果

理解数据库连接池底层原理之手写实现


本文转自zfz_linux_boy 51CTO博客,原文链接:http://blog.51cto.com/zhangfengzhe/2069971,如需转载请自行联系原作者

相关文章
|
3月前
|
算法 关系型数据库 MySQL
【MySQL 解析】数据库的乐观锁和悲观锁实现原理
【1月更文挑战第11天】【MySQL 解析】数据库的乐观锁和悲观锁实现原理
|
3月前
|
NoSQL 中间件 API
分布式锁【数据库乐观锁实现的分布式锁、Zookeeper分布式锁原理、Redis实现的分布式锁】(三)-全面详解(学习总结---从入门到深化)(下)
分布式锁【数据库乐观锁实现的分布式锁、Zookeeper分布式锁原理、Redis实现的分布式锁】(三)-全面详解(学习总结---从入门到深化)
81 2
|
3月前
|
NoSQL Java API
分布式锁【数据库乐观锁实现的分布式锁、Zookeeper分布式锁原理、Redis实现的分布式锁】(三)-全面详解(学习总结---从入门到深化)(上)
分布式锁【数据库乐观锁实现的分布式锁、Zookeeper分布式锁原理、Redis实现的分布式锁】(三)-全面详解(学习总结---从入门到深化)
73 0
|
4月前
|
druid 网络协议 Java
再有人问你数据库连接池的原理,这篇文章甩给他!
在 Spring Boot 项目中,数据库连接池已经成为标配,然而,我曾经遇到过不少连接池异常导致业务错误的事故。很多经验丰富的工程师也可能不小心在这方面出现问题。 在这篇文章中,我们将探讨数据库连接池,深入解析其实现机制,以便更好地理解和规避潜在的风险。
|
1月前
|
缓存 Java 数据库连接
mybatis 数据库缓存的原理
MyBatis 是一个流行的 Java 持久层框架,它封装了 JDBC,使数据库交互变得更简单、直观。MyBatis 支持两级缓存:一级缓存(Local Cache)和二级缓存(Global Cache),通过这两级缓存可以有效地减少数据库的访问次数,提高应用性能。
282 1
|
2月前
|
存储 关系型数据库 数据库
数据库索引的原理,为什么要用 B+树,为什么不用二叉树?
数据库索引的原理,为什么要用 B+树,为什么不用二叉树?
|
2月前
|
NoSQL Java API
分布式锁【数据库乐观锁实现的分布式锁、Zookeeper分布式锁原理、Redis实现的分布式锁】(三)-全面详解(学习总结---从入门到深化)
分布式锁【数据库乐观锁实现的分布式锁、Zookeeper分布式锁原理、Redis实现的分布式锁】(三)-全面详解(学习总结---从入门到深化)
298 0
|
3月前
|
存储 传感器 数据挖掘
请解释一下时序数据库的工作原理,并提供一个使用时序数据库的实际应用场景。
请解释一下时序数据库的工作原理,并提供一个使用时序数据库的实际应用场景。
183 0
|
3月前
|
存储 数据采集 搜索推荐
请解释一下搜索引擎数据库的工作原理,并提供一个使用搜索引擎数据库的实际应用场景。
请解释一下搜索引擎数据库的工作原理,并提供一个使用搜索引擎数据库的实际应用场景。
22 0
|
3月前
|
存储 算法 搜索推荐
请解释一下图形存储数据库的工作原理,并提供一个使用图形存储数据库的实际应用场景。
请解释一下图形存储数据库的工作原理,并提供一个使用图形存储数据库的实际应用场景。
52 0