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

数据库
数据库连接池的基本思想是:为数据库连接建立一个“缓冲池”,预先在池中放入一定数量的数据库连接管道,需要时,从池子中取出管道进行使用,操作完毕后,在将管道放入池子中,从而避免了频繁的向数据库申请资源,释放资源带来的性能损耗。

前言

数据库连接池的基本思想是:为数据库连接建立一个“缓冲池”,预先在池中放入一定数量的数据库连接管道,需要时,从池子中取出管道进行使用,操作完毕后,在将管道放入池子中,从而避免了频繁的向数据库申请资源,释放资源带来的性能损耗。在如今的分布式系统当中,系统的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测试

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

运行结果

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

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

 

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

责任编辑:庞桂玉 来源: 51CTO博客
相关推荐

2019-11-27 10:31:51

数据库连接池内存

2011-05-19 09:53:33

数据库连接池

2010-03-18 15:09:15

python数据库连接

2009-06-24 07:53:47

Hibernate数据

2020-12-18 05:42:46

reduxactions

2009-07-17 13:32:49

JDBC数据库

2017-06-22 14:13:07

PythonMySQLpymysqlpool

2009-06-16 09:25:31

JBoss配置

2020-04-21 23:14:08

数据并发控制

2021-08-12 06:52:01

.NET数据库连接池

2018-10-10 14:27:34

数据库连接池MySQL

2020-04-30 14:38:51

数据库连接池线程

2011-04-19 11:02:57

数据库分页

2009-07-29 09:33:14

ASP.NET数据库连

2018-01-03 14:32:32

2010-03-18 14:55:17

Python数据库连接

2011-07-29 15:11:42

WeblogicOracle数据库连接

2023-06-08 07:25:56

数据库索引数据结构

2017-02-08 11:00:50

数据库索引类型

2021-07-05 07:51:43

JVM底层Python
点赞
收藏

51CTO技术栈公众号