连接池的本质是构建一个容器,容器是用来存创建好的线程,http连接、数据库连接、netty连接等

各个连接池的使用大致分为三个部分

1、首先是初始化连接池,根据设置相应的参数、连接池的大小、核心连接数等参数,初始化创建数据库、http连接、netty连接以及jdk线程等。

2、第二步是连接池的使用,直接从连接池中、线程中取出资源即可使用,使用完后交还给连接池、线程池,通过池容器对线程进行管理。

3、对于连接池维护,连接池、线程池来维护连接、线程状态,不可用连接、线程进行销毁,正在使用连接、线程进行状态标注,连接、线程不够后并且少于设置最大连接、线程数,要进行新连接、线程创建。

什么情况下使用连接池?

对于一个简单的数据库应用,由于对于数据库的访问不是很频繁。这时可以简单地在需要访问数据库时,就新创建一个连接,用完后就关闭它,这样做也不会带来什么明显的性能上的开销。但是对于一个复杂的数据库应用,情况就完全不同了。频繁的建立、关闭连接,会极大的减低系统的性能,因为对于连接的使用成了系统性能的瓶颈。

使用连接池的好处

连接复用。通过建立一个数据库连接池以及一套连接使用管理策略,使得一个数据库连接可以得到高效、安全的复用,避免了数据库连接频繁建立、关闭的开销。

对于共享资源,有一个很著名的设计模式:资源池。该模式正是为了解决资源频繁分配、释放所造成的问题的。把该模式应用到数据库连接管理领域,就是建立一个数据库连接池,提供一套高效的连接分配、使用策略,最终目标是实现连接的高效、安全的复用。

连接池的实现

数据库连接池的基本原理是在内部对象池中维护一定数量的数据库连接,并对外暴露数据库连接获取和返回方法。

外部使用者可通过 getConnection 方法获取连接,使用完毕后再通过 close 方法将连接返回,注意此时连接并没有关闭,而是由连接池管理器回收,并为下一次使用做好准备。

Java 中有一个 DataSource 接口, 数据库连接池就是 DataSource 的一个实现

常用数据库连接池

Apache DBCP官网:http://commons.apache.org/proper/commons-dbcp/

C3P0官网:https://www.mchange.com/projects/c3p0/index.html

DruidGitHub:https://github.com/alibaba/druid

一、JDBC数据库连接池的必要性

在使用开发基于数据库的web程序时,传统的模式基本是按以下步骤:

  ①在主程序(如servlet、beans)中建立数据库连接。

  ②进行sql操作

  ③断开数据库连接。

  这种模式开发,存在的问题:

  1.   ①普通的JDBC数据库连接使用 DriverManager 来获取,每次向数据库建立连接的时候都要将 Connection 加载到内存中,再验证用户名和密码(得花费0.05s~1s的时间)。需要数据库连接的时候,就向数据库要求一个,执行完成后再断开连接。这样的方式将会消耗大量的资源和时间。数据库的连接资源并没有得到很好的重复利用.若同时有几百人甚至几千人在线,频繁的进行数据库连接操作将占用很多的系统资源,严重的甚至会造成服务器的崩溃。   
  2. ②对于每一次数据库连接,使用完后都得断开。否则,如果程序出现异常而未能关闭,将会导致数据库系统中的内存泄漏,最终将导致重启数据库。   
  3. ③这种开发不能控制被创建的连接对象数,系统资源会被毫无顾及的分配出去,如连接过多,也可能导致内存泄漏,服务器崩溃。

二、数据库连接池(connection pool)

  数据库连接池简单介绍

  为解决传统开发中的数据库连接问题,可以采用数据库连接池技术。

  数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”。预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去。

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

  数据库连接池在初始化时将创建一定数量的数据库连接放到连接池中,这些数据库连接的数量是由最小数据库连接数来设定的。无论这些数据库连接是否被使用,连接池都将一直保证至少拥有这么多的连接数量。连接池的最大数据库连接数量限定了这个连接池能占有的最大连接数,当应用程序向连接池请求的连接数超过最大连接数量时,这些请求将被加入到等待队列中。

  数据库连接池工作原理:

  数据库连接池工作原理

  数据库连接池技术的优点

  资源重用:

  ①由于数据库连接得以重用,避免了频繁创建,释放连接引起的大量性能开销。在减少系统消耗的基础上,另一方面也增加了系统运行环境的平稳性。

  更快的系统反应速度:   数据库连接池在初始化过程中,往往已经创建了若干数据库连接置于连接池中备用。此时连接的初始化工作均已完成。对于业务请求处理而言,直接利用现有可用连接,避免了数据库连接初始化和释放过程的时间开销,从而减少了系统的响应时间

  新的资源分配手段:   对于多应用共享同一数据库的系统而言,可在应用层通过数据库连接池的配置,实现某一应用最大可用数据库连接数的限制,避免某一应用独占所有的数据库资源

  统一的连接管理,避免数据库连接泄露:   在较为完善的数据库连接池实现中,可根据预先的占用超时设定,强制回收被占用连接,从而避免了常规数据库连接操作中可能出现的资源泄露

三、两种开源的数据库连接池

  JDBC 的数据库连接池使用 javax.sql.DataSource 来表示,DataSource 只是一个接口,该接口通常由服务器(Weblogic, WebSphere, Tomcat)提供实现,也有一些开源组织提供实现:   ①DBCP 数据库连接池   ②C3P0 数据库连接池

  DataSource 通常被称为数据源,它包含连接池和连接池管理两个部分,习惯上也经常把 DataSource称为连接池

  数据源和数据库连接不同,数据源无需创建多个,它是产生数据库连接的工厂,因此整个应用只需要一个数据源即可。

  当数据库访问结束后,程序还是像以前一样关闭数据库连接:conn.close(); 但上面的代码并没有关闭数据库的物理连接,它仅仅把数据库连接释放,归还给了数据库连接池。

c3p0 服务启动获取连接超时_JDBC数据库连接池相关推荐

  1. c3p0 服务启动获取连接超时_微服务架构中的熔断、降级

    微服务架构中熔断和降级是保证服务高可用的一项重要功能点,微服务区别于一体化项目的最大区别也再于熔断和降级,很多微服务项目的开发人员对熔断的理解就是当服务不可用的时候,为了让整体服务可以正常运行,需要让 ...

  2. c3p0 服务启动获取连接超时_c3p0获取连接Connection后的Close()---释疑

    abstract class AbstractPoolBackedDataSource extends PoolBackedDataSourceBase implements PooledDataSo ...

  3. Druid获取连接超时,导致服务不可用

    前言 一个微服务模块在运行一段时间之后,整体服务就不可用了,但是服务却没有打印任何错误日志.而对服务进行重启之后,服务就可以暂时提供一段时间服务,过一段时间之后再次不可用. 分析 服务进行重启就可以正 ...

  4. mysql启动服务但无法连接不上_mysql服务启动却连接不上两种解决办法

    这篇文章主要为大家详细介绍了mysql服务启动却连接不上的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 mysql服务启动,但是连接不上,如何解决? 登陆报错: root@localho ...

  5. 记一次Mysql连接未满但程序却报错连接已满获取连接超时GetConnectionTimeoutException的问题

    1.问题描述 今天同事找到我,让我帮忙查一个问题,据说已经持续一个月: 之前服务正常,问题在上个月开始出现. 服务运行大概1天左右,后台开始报错:获取数据库连接失败GetConnectionTimeo ...

  6. Mysql -uroot -p 登陆不上_mysql服务启动却连接不上的解决方法

    mysql服务启动,但是连接不上,如何解决? 登陆报错: root@localhost:~# mysql -u root -p Enter password: ERROR 2002 (HY000): ...

  7. java jdbc close原理_JDBC数据库连接池原理

    JDBC是java数据库连接的简称.它是一种用于实行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用java语言编写的类和接口组成.其相关的API都在java.sql.*包下 ...

  8. HIVE-启动服务-启动DG连接-迁移数据LINUX-HDFS-HIVE

    0.linux指令,按照名字搜索正在运行的进程:ps -ef grep | hive 1.将linux中的数据传入hdfs系统中:此时要使用上传日期作为路径,开始维护分区表的潜在条件${do_date ...

  9. kettle mysql连接超时_kettle 数据库连接中断重置

    项目适用kettle作为etl工具,源数据库为mysql库,目标库为oracle.在持续的循环调度中,经常发现oracle的数据库连接中断,需要重置. 具体报错信息如下: INFO  26-12 23 ...

最新文章

  1. sql输出表中重复数据
  2. OpenCV下利用傅里叶变换和逆变换实现图像卷积算法,并附自己对于卷积核/模板核算子的理解
  3. 请教SQL对日期格式化的写法
  4. 解决orcale报ORA-28001: the password has expired
  5. 每日一笑 | 一些关于集合的知识
  6. cmosfixr插件怎么用_3dmax插件神器|怎么用3dmax插件神器去完成背景墙的效果图设计?...
  7. 深度学习(三十七)优化求解系列之(1)简单理解梯度下降
  8. php 忽略加载动态某个目录,限定某个目录禁止解析php 、限制user_agent 、php的配制文件、PHP的动态扩展模块...
  9. linux在安全模式下如何编辑,在安全模式下修改initrd文件
  10. html插入视频时不自动播放,html5中嵌入视频自动播放的问题解决
  11. vscode:设置语言为中文
  12. 绿坝进程关闭的简单方法
  13. xx排排网数据加密(js逆向)
  14. Hierachy Viewer 使用 monitor命令
  15. 3.10编写程序,计算并输出0到1000含有七或者7倍数的整数之和和及个数
  16. 保健品消费者需求调查方案
  17. 推荐用于环境识别的机器人摄像头
  18. QMap 迭代器崩溃分析
  19. Python游戏概率补偿算法-马尔科夫链
  20. WD移动硬盘unlock解锁之后看不到盘符的解决办法

热门文章

  1. Arrays.asList()使用时的注意事项,这个结论同可适用于Stream.of()___Arrays.stream和Stream.of
  2. SpringBoot的编码问题
  3. Mybatis源码分析之(二)根据配置文件创建SqlSessionFactory(Configuration的创建过程)
  4. 基于easypoi实现自定义模板导出excel
  5. linux电脑合盖后卡住了,解决ubuntu合盖后无法唤醒
  6. c++byte数组和文件的相互转换_终于!word、excel、ppt文件相互转换技巧来了!
  7. python如何运行源文件_Python如何运行
  8. linux 1号硬盘不能用,linux 挂载硬盘的疑问 : IDE1 上的接口无法使用.
  9. MATLAB接收机位置解算,GPS-receiver GPS软件接收机代码 完整的捕获 解算定位 (可 8个通道) matlab 240万源代码下载- www.pudn.com...
  10. Log4j文件配置教程大全