数据库连接池 下载本文

内容发布更新时间 : 2024/5/2 13:01:28星期一 下面是文章的全部内容请认真阅读。

班级编号:VIP14 学员名字:端碗吹水 课程名称:数据库连接池

数据库连接池简介:

数据库连接对象是有限资源,所以数据库连接池是用于负责分配、管理和释放数据库连接对象,它允许应用程序重复使用一个现有的数据库连接对象,而不是再重新建立一个;这一点实际上和线程池的概念差不多。数据库连接池会释放空闲时间超过最大空闲时间的数据库连接来避免因为没有释放数据库连接而引起的数据库连接遗漏,这项技术能明显提高对数据库操作的性能。

不使用线程池的话用户每次请求都需要向数据库获得链接,而数据库创建连接通常需要消耗相对较大的资源,创建时间也较长。假设网站一天10万访问量,数据库服务器就需要创建10万次连接,极大的浪费数据库的资源,并且极易造成数据库服务器内存溢出、拓机。如下图所示:

数据库连接池负责分配,管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是重新建立一个。如下图所示:

在Java连接MySQL数据库中,最常用的是DBCP和C3P0连接池。DBCP(DataBase Connection Pool)数据库连接池,是java数据库连接池的一种,由Apache开发,也是 tomcat 使用

的连接池组件。C3P0则是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。目前使用它的开源项目有Hibernate,Spring等。 c3p0与dbcp区别:

dbcp没有自动回收空闲连接的功能 c3p0有自动回收空闲连接功能

一般情况下,c3p0的使用率较高于dbcp,在公司用得比较多的也是c3p0。

数据库连接池的运行机制:

(1) 程序初始化时创建连接池 (2) 使用时向连接池申请可用连接 (3) 使用完毕,将连接返还给连接池 (4) 程序退出时,断开所有连接,并释放资源

示意图: