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

前言

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

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

ddc5821b382ecbb65aa36c53904ec157.png

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

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

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

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

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

c6f4fa4cd855d1f2ebbdf426e60acd3d.png

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

MyDefaultPool是IMyPool的实现。

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

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

DBConfigXML代表外部配置文件。

Test用于测试。

DBConfigXML

bf6a5222533e5f93dad88aedac4f628e.png

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

MyPooledConnection

fe64962ceb3eedafb44f3c91b0eae8d1.png

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

IMyPool

234e0428d6e38a62841b01580a6b21da.png

MyDefaultPool

19b313a1619b3abd069350991e79949f.png

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

MyDefaultPool需要初始化

46f65b1cf482f951aa7e6be919e2d4c9.png

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

createMyPooledConnection接口实现

f2da5b6ee44f5bf993958fb216d99e12.png

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

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

getMyPooledConnection接口实现

b056f2808417d77d0ebf1d2cbffc10a3.png

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

getRealConnectionFromPool

3ec5aab2518ef8542e329f4f670c467b.png

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

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

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

MyPoolFactory

885f3783384e663c7bafb59228e9d3a9.png

Test测试

480469c7530d09a9c6be2af394b29609.png

运行结果

a9712c2366ea3d56cf309b24b6ff4f26.png

好了,到这里,一个迷你版的数据库连接池就有模有样了!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值