数据库连接池负责分配、管理和释放数据库连接,其基本思想就是为数据库建立一个“缓冲池”,预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕后再放回去。
可以通过设定连接池最大连接数来防止系统无尽的与数据库连接。更为重要的是我们可以通过连接池的管理机制监视数据库的连接的数量和使用情况,为系统开发和测试及性能调整提供依据。
(1)使用连接池的原因:创建连接和释放连接都有很大的开销(尤其是数据库服务器不在本地时,每次建立连接都需要进行TCP的三次握手,释放连接需要进行TCP的四次握手,造成的开销是不可忽视的),因此是为了提升系统访问数据库的性能。典型的用空间换取时间的策略(浪费了空间存储连接,但是节省了创建和释放连接的时间)。
(2)不使用连接池的流程:
连接池的TCP连接、数据库认证、数据库关闭、Tcp关闭步骤会复用。
(3)普通连接与连接池的比较:
优点 | 缺点 | |
普通连接 | 1.实现简单 | 1.网络IO较多 2.数据库的负载较高 3.响应时间较长及QPS每秒查询率较低 4.应用频繁的创建连接和关闭连接,导致临时对象较多,GC垃圾回收频繁 5.关闭连接后,会出现大量TIME_WAIT的TCP状态 |
连接池 | 1.较少的网络开销 2.系统的性能会有一个实质的提升 3.没有大量麻烦的TIME_WAIT状态 |
(1)连接步骤:①连接池的建立;②连接池中连接的使用管理;③连接池的关闭
第一、连接池的建立。一般系统初始化时,连接池会根据系统配置建立,并在池中创建了几个连接对象,以便使用时能从连接池中获取。池中的连接不能随意创建和关闭。Java中提供了很多容器类可以方便的构建连接池,例如Vector、Stack等。
第二、连接池的管理。连接池管理策略是连接池机制核心,对性能有很大影响。管理策略:当客户请求数据库连接时,首先查看连接池中是否有空闲连接,1)如果存在空闲连接,则使用空闲连接;2)如果没有空闲连接,则查看当前所开的连接数是否已经达到了最大连接数,如果没达到就重新创建一个连接给请求的客户;3)如果达到就按设定的最大等待时间进行等待,如果超出最大等待时间,则抛出异常给客户。
第三、连接池的关闭。当应用程序退出时,关闭连接池中所有的连接,释放连接池相关资源,和创建过程相反。
(2)连接池主要参数:
(3)连接池需要注意的问题:
(一代连接池)C3P0、DBCP、(二代连接池)Druid、HikariCP,一二代产品区分最重要的特征是架构和设计时采用的线程模型。一般来讲采用单线程同步的架构设计都属于第一代连接池,采用多线程异步架构的则属于第二代。
(1)C3P0:Hibernate曾将其作为内置的数据库连接池,稳定性的到业内认可。功能简单易用,稳定性好;但是性能非常差,且架构涉及过于复杂,重构十分复杂
(2)DBCP:DataBase Connection Pool,属于Apache顶级项目Commons中的核心子项目,在Apache生态圈中影响十分广泛。DBCP并不是独立实现连接池功能的,它内部依赖于Commons中的另一个子项目Pool,连接池最核心的“池”,就是由Pool组件提供的,因此,DBCP的性能实际上就是Pool的性能(因此DBCP只能做小版本更新,真正大版本更迭则完全依托于pool)。DBCP1.x版本一直延续着单线程设计模式,2.x版本才采用多线程(2.x版本已经稳稳达到了和新一代产品同级别的性能指标)
(3)HikariCP(性能无敌):性能极好,具体性能比较见下面总结表格。
(4)Druid(功能全面):阿里优秀开源项目中的一个,除此外还有众多,如fastJson、dubbo项目、AliSQL软件等。除了提供性能卓越的连接池性能外,还集成了SQL监控,黑名单拦截等功能。Durid是“为监控而生”。它不仅仅是一个数据库连接池,还包含了ProxyDriver,一系列内置的JDBC组件库,一个SQL Parser。
Druid配置详解见:https://www.cnblogs.com/cymiao/p/8432681.html
Druid实例见:https://blog.csdn.net/h294590501/article/details/80428182
优点 | 缺点 | 应用 | |
C3P0 | 1.功能简单易用 2.稳定性好 |
1.性能非常差 2.构涉及过于复杂,使得重构十分复杂 |
Hibernate |
DBCP (Apache) |
1.最核心的池依赖于Apache的另一个项目Commons的Pool,版本更迭完全依托于Pool项目 | ||
HikariCP (性能无敌) |
1.性能强劲,稳定性好(原因如下) ①字节码精简:代码优化 ②优化代理和拦截器:减少代码 ③自定义数组类型:FastStatement List代替ArrayList,避免每次get()进行range check,避免remove()的全扫描 ④自定义类型集合:ConcurrentBag ,提高并发读写的效率 ⑤其他缺陷的优化
|
||
Druid (功能全面) |
1.功能全面:集成连接池、SQL监控、黑名单拦截等功能 2.强大的监控特性,可以清晰的知道连接池和SQL的工作情况 3.方便扩展:提供了Filter-Chain模式的API,可以自己编写Filter拦截JDBC中的任何方法 4.集合了开源和商业数据库连接池的优秀特性,并结合阿里的大规模苛刻生产环境的使用经验进行优化。 |
阿里的项目 |
本文部分内容参考博客,https://blog.csdn.net/crankz/article/details/82874158