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

发布时间:2020-05-24 18:59:54 作者:江彩
来源:网络 阅读:552

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

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

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

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

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

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

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测试
理解数据库连接池底层原理之手写实现
运行结果
理解数据库连接池底层原理之手写实现

推荐阅读:
  1. docker底层原理介绍
  2. hbase的底层原理

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

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

上一篇:python map函数(23)

下一篇:Android测试

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》