Java技术分享:什么是数据库连接池?

Posted 程序员的小傲娇

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java技术分享:什么是数据库连接池?相关的知识,希望对你有一定的参考价值。

在JDBC编程中,每次创建和断开Connection对象都会消耗一定的时间和IO资源。这是因为在Java程序与数据库之间建立连接时,数据库端要验证用户名和密码,并且要为这个连接分配资源。Java程序则要把代表连接的java.sql.Connection对象等加载到内存中,所以建立数据库连接的开销很大,尤其是在大量的并发访问时。

假如某网站一天的访问量是10万,那么该网站的服务器就需要创建、断开连接10万次,频繁地创建、断开数据库连接势必会影响数据库的访问效率,甚至导致数据库崩溃。

为了避免频繁地创建数据库连接,工程师们提出了数据库连接池技术。数据库连接池负责分配、管理和释放数据库连接,它允许应用程序重复使用现有的数据库连接,而不是重新建立。接下来,通过一张图来简单描述应用程序如何通过连接池连接数据库。

从上图可以看出,数据库连接池在初始化时将创建一定数量的数据库连接放到连接池中,当应用程序访问数据库时并不是直接创建Connection,而是向连接池“申请”一个Connection。如果连接池中有空闲的Connection,则将其返回,否则创建新的Connection。使用完毕后,连接池会将该Connection回收,并交付其他的线程使用,以减少创建和断开数据库连接的次数,提高数据库的访问效率。

以上就是关于数据库连接池的详细介绍,希望能帮到大家。想了解更多Java知识,可以关注小千,后期会继续分享Java技术知识。

本文来自千锋教育,转载请注明出处。

以上是关于Java技术分享:什么是数据库连接池?的主要内容,如果未能解决你的问题,请参考以下文章

Java技术分享:什么是数据库连接池?

技术分享前尘—数据连接池下的至暗之处

数据层优化-jdbc连接池简述druid简介

技术分享 | 探究 Druid 连接池探活方式的实现

java数据库连接池技术原理

使用Go实现一个数据库连接池