`
sunshine518
  • 浏览: 45635 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

连接池工作原理

阅读更多
一般情况下,在使用开发基于数据库的WEB程序时,传统的模式基本是按以下步骤:
  1. 在主程序(如Servlet、Beans)中建立数据库连接。
  2. 进行SQL操作,取出数据。
  3. 断开数据库连接。
  使用这种模式开发,存在很多问题。首先,我们要为每一次WEB请求(例如察看某一篇文章的内容)建立一次数据库连接,对于一次或几次操作来讲,或许你觉察不到系统的开销,但是,对于WEB程序来讲,即使在某一较短的时间段内,其操作请求数也远远不是一两次,而是数十上百次(想想全世界的网友都有可能在您的网页上查找资料),在这种情况下,系统开销是相当大的。事实上,在一个基于数据库的WEB系统中,建立数据库连接的操作将是系统中代价最大的操作之一。很多时候,可能您的网站速度瓶颈就在于此。
  其次,使用传统的模式,你必须去管理每一个连接,确保他们能被正确关闭,如果出现程序异常而导致某些连接未能关闭,将导致数据库系统中的内存泄露,最终我们将不得不重启数据库。
  针对以上问题,我们首先想到可以采用一个全局的Connection对象,创建后就不关闭,以后程序一直使用它,这样就不存在每次创建、关闭连接的问题了。但是,同一个连接使用次数过多,将会导致连接的不稳定,进而会导致WEB SERVER的频频重启。故而,这种方法也不可取。实际上,我们可以使用连接池技术来解决上述问题。首先,介绍一下连接池技术的基本原理。顾名思义,连接池最基本的思想就是预先建立一些连接放置于内存对象中以备使用:
 




   
如图所示,当程序中需要建立数据库连接时,只须从内存中取一个来用而不用新建。同样,使用完毕后,只需放回内存即可。而连接的建立、断开都有连接池自身来管理。同时,我们还可以通过设置连接池的参数来控制连接池中的连接数、每个连接的最大使用次数等等。通过使用连接池,将大大提高程序效率,同时,我们可以通过其自身的管理机制来监视数据库连接的数量、使用情况等。下面我们以一个名为ConnectionPool的连接池为例来看看连接池的实现。先看看ConnectionPool的基本属性:
  m_ConnectionPoolSize:连接池中连接数量下限
  m_ConnectionPoolMax:连接池中连接数量上限
  m_ConnectionUseCount:一个连接的最大使用次数
  m_ConnectionTimeout:一个连接的最长空闲时间
  m_MaxConnections = -1:同一时间的最大连接数
  m_timer:定时器
  这些属性定义了连接池与其中的每个连接的有效状态值。连接池的自我管理,实际上就是通过定时的对每个连接的状态、连接的数量进行判断而进行相应操作。其管理流程如下:






通过上图,我们可以定义出ConnectionPool要完成管理所需要的基本接口:
public class ConnectionPool implements TimerListener{
  public boolean initialize() //连接池初始化
  public void destroy() //连接池的销毁
  public synchronized java.sql.Connection getConnection() //取一个连接
  public synchronized void close() //关闭一个连接
  private synchronized void removeFromPool() //把一个连接从连接池中删除
  private synchronized void fillPool() //维护连接池大小
  public synchronized void TimerEvent() //定时器事件处理函数
}
  通过这几个接口,已经可以完成连接池的基本管理。在TimeEvent()函数中完成连接池的状态检验工作,fillPool()时连接池至少保持最小连接数。因为我们要保存每一个连接的状态,所以还需要一个数据库连接对象:
class ConnectionObject{
  public java.sql.Connection con; public boolean inUse; //是否被使用标志
  public long lastaccess(小型网站之最爱); //最近一次开始使用时间

  数据连接池:系统启动初始化几个静态的数据连接,采用记数策略(用来记录连接此连接的用户个数),复用引用记数最小的连接.释放连接是放入连接池,而不是关闭连接.
      建议:minConn是当应用启动的时候连接池所创建的连接数,如果过大启动将变慢,但是启动后响应更快;如果过小启动加快,但是最初使用的用户将因为连接池中没有足够的连接不可避免的延缓了执行速度。因此应该在开发的过程中设定较小minConn,而在实际应用的中设定较大minConn.
  • 大小: 18.3 KB
  • 大小: 69.1 KB
分享到:
评论

相关推荐

    数据库连接池的工作原理

    数据库连接池的工作原理涉及到多个层面,包括连接的创建与复用、连接池的管理以及性能优化策略。接下来,我们将深入探讨这些核心知识点。 1. **连接的创建与复用** - **连接初始化**:当应用程序启动时,连接池会...

    Java中数据库连接池原理机制的详细讲解

    本文讨论的连接池包括一个连接池类(DBConnectionPool)和一个连接池管理类(DBConnetionPoolManager)。连接池类是对某一数据库所有连接的“缓冲池”,主要实现以下功能:从连接池获取或创建可用连接;使用完毕之后...

    连接池的基本工作原理

    【连接池的基本工作原理】 连接池是数据库管理中一种重要的技术,它的主要目的是优化数据库连接的使用,提高系统性能和资源利用率。连接池的核心思想是通过维持一个预创建的数据库连接池,使得应用程序在需要时可以...

    连接池源码和视频教程

    以下将详细阐述连接池的基本概念、工作原理以及Java中如何使用连接池。 1. 连接池基本概念: 连接池,也称为数据库连接池,是一种在多线程应用程序中管理数据库连接的机制。它通过预创建并复用数据库连接来提高...

    JSP数据库连接池连接实例

    下面,我们将详细讨论JSP中数据库连接池的实现、工作原理以及如何实例化。 1. **数据库连接池概念**: 数据库连接池是在应用服务器启动时创建的一组预设的数据库连接。这些连接在应用需要时被复用,而不是每次请求...

    连接池实现原理及效率测试

    连接池的工作流程大致如下: 1. 应用启动时,连接池会预先配置并创建一定数量的数据库连接,放入池中。 2. 当客户端需要与数据库交互时,它向连接池申请一个连接,而不是直接创建新的连接。 3. 使用完毕后,客户端将...

    jdbc数据库连接池

    ** 数据库连接池工作原理 ** 数据库连接池的工作原理主要包括以下几个步骤: 1. 初始化:连接池在启动时根据配置预先创建一定数量的数据库连接。 2. 请求连接:当应用程序需要与数据库通信时,向连接池请求一个...

    jdbc连接池配置(优化连接速度)

    本文将详细讲解JDBC连接池的工作原理、配置方法以及如何通过优化来提升连接速度。 JDBC(Java Database Connectivity)是Java语言访问数据库的标准接口,而JDBC连接池则是一种对数据库连接进行管理和复用的技术。它...

    JDBC数据库连接池实现原理

    通过以上步骤,你可以全面了解JDBC数据库连接池的实现原理,以及如何在实际项目中有效地使用和配置它。在实践中,结合Oracle数据库的特性和JDBC API,可以更好地优化数据库操作,提升系统的稳定性和效率。

    数据库的连接池原理,基本概念及原理,服务器自带的连接池

    数据库的连接池原理 数据库的连接池原理是指为了解决数据库连接资源的低效管理而采用的技术方法。其基本思想是为数据库连接建立一个“缓冲池”,预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从...

    Java数据库连接池的原理与应用.pdf

    数据库连接池的工作原理可从以下几个方面理解: 1. 建立连接池 在应用程序启动时,系统会预先创建一定数量的数据库连接,并将这些连接存放在一个“池”里。这些连接是预先配置好的,并且不会被随意关闭,之后应用...

    DBCP(数据库连接池)

    **数据库连接池工作原理** 数据库连接池在初始化时会创建一定数量的数据库连接并保留在内存中。当应用程序需要与数据库通信时,它会从连接池中获取一个已经建立好的连接,使用完毕后不再关闭而是归还给连接池,供...

    RabbitMQ客户端连接池的原理及源码

    本文将深入探讨RabbitMQ客户端连接池的工作原理,并分析其源码,以期帮助读者理解如何有效地利用连接池优化系统性能。 连接池的基本思想是预先创建一定数量的连接并保持空闲状态,当应用需要时可以从池中获取,使用...

    java数据库连接池Proxool

    标签“源码”意味着我们可以研究Proxool的源代码,了解其内部实现机制,这对于深入理解数据库连接池的工作原理和优化应用性能非常有帮助。 标签“工具”表明Proxool作为一个工具类库,可以方便地集成到各种Java项目...

    JAVA数据库连接池完整源码(简单易用带详细注释)

    数据库连接池是Java应用程序中非常重要的一个组件,它在处理...总之,这份源码提供了一个学习数据库连接池实现的实例,通过深入研究,可以加深对数据库连接池工作原理的理解,并有助于在实际项目中优化数据库访问性能。

    java数据库连接池

    总的来说,`jdbcPool.jar`是一个实用的Java数据库连接池实现,它提供了一种便捷的方式用于管理数据库连接,同时也为开发者提供了学习和研究连接池工作原理的机会。通过阅读源代码和按照`readme.txt`中的指南进行实践...

    jdbc连接池原理

    关于jdbc连接池连接数据库的原理

Global site tag (gtag.js) - Google Analytics