`
fengqx
  • 浏览: 99622 次
  • 性别: 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; //最近一次开始使用时间
  public int useCount; //被使用次数
}
加入了ConnectionObject对象后,在ConnectionPool中操作的应该只是ConnectionObject,而其他进程需要的只是ConnectionObject的con属性,因此我们再加入一个类,作为其他进程获得与返回连接的接口: CLASS Conn{
  GetConnection(); //从连接池中取出一个有效连接
  CloseConnection(); //返回连接,此时并没有关闭连接,只是放回了连接池
  DestroyPool(); //销毁连接池
}
  最后我们的整个系统总的架构如下:
        
  通过上面的介绍,我们可以看出,连接池技术的关键就是其自身的管理机制,以上的管理流程只是本人一点见解,关键是想向大家介绍一种思路,在此基础上,您可以进一步完善连接池技术为您所用。
分享到:
评论

相关推荐

    3、ConnectionPool---Web容器

    当我们谈论Web容器时,如Tomcat、Jetty等,它们通常会内置或支持连接池的集成,以便更好地处理来自多个并发用户的请求。 【描述】: 虽然描述为空,但我们可以推断,这篇博客可能详细解释了如何在Web容器中配置和...

    conn连接问题

    5. 连接池:为了提高性能,OLE DB支持连接池技术。连接池可以复用已建立的数据库连接,减少创建和销毁连接的开销。在配置时,需要考虑连接池的大小、超时时间等因素。 6. 安全性:在使用OLE DB连接数据库时,要确保...

    使用jdbc的高级数据库操作

    7. **连接池**:在实际应用中,使用连接池(如C3P0、HikariCP、Apache DBCP等)管理数据库连接,可以提高性能并优化资源利用。连接池会预先创建一定数量的连接,当需要时分配给应用程序,用完后归还。 8. **JDBC...

    java连接oracle

    在实际应用中,我们通常会使用连接池来管理数据库连接,如C3P0、HikariCP或Apache DBCP等,以提高性能和资源利用率。 此外,开发过程中,可能还需要配置Oracle的TNSNames.ora文件,这是一个网络服务名的配置文件,...

    JAVA6高级编程代码1

    在Java 6中,JDBC提供了增强的性能和易用性,允许开发者高效地执行SQL语句、管理连接池和事务。理解JDBC的核心概念如Connection、Statement、PreparedStatement和ResultSet是至关重要的。使用PreparedStatement可以...

    PHP轻量级数据库框架PHP更简单高效的数据库操作方式

    5. **连接池**:对于高并发场景,连接池可以优化数据库连接的创建和销毁,提高性能。一些框架会内置连接池管理机制,比如Slim Framework的PDO-Connection Pool。 6. **错误处理与日志记录**:良好的框架会提供优雅...

    php.rar_PHP 数据库

    在实际项目中,我们还会使用数据库连接池来管理数据库连接,提高应用性能。连接池预先创建并维护一定数量的连接,避免了频繁建立和关闭连接的开销。 总的来说,"PHP与数据库连接"涵盖了PHP如何与数据库建立连接、...

    databaseDriver

    在开发过程中,为了优化性能和安全性,通常会采用连接池管理数据库连接,如Apache的DBCP或C3P0,这样可以复用已建立的连接,减少数据库资源的消耗,并且能更好地管理连接的生命周期。 此外,随着ORM(对象关系映射...

    Java_Apache的冰山.zip

    此外,Apache HttpClient是一个Java库,用于发起HTTP请求,它支持多种协议特性,如HTTP/1.1,HTTPS,以及连接池管理。在进行Web服务调用或爬虫开发时,这个库非常实用。 另外,Apache也贡献了许多数据处理和存储的...

    spring集成redis,集成redis集群

    - **连接池管理**:合理设置连接池大小,避免资源浪费和性能瓶颈。 - **安全与访问控制**:配置Redis的访问控制和SSL加密,保障数据安全。 博客链接中提到的可能详细介绍了这些步骤,包括源码示例和工具使用。通过...

    Laravel开发-laravoole

    5. **数据库连接池**:通过连接池管理数据库连接,laravoole可以避免频繁创建和销毁连接,提高数据库操作效率。 6. **长连接**:对于需要保持用户状态的应用,laravoole可能实现了基于Swoole或Workerman的长连接...

    滴答拍摄影项目.zip

    例如,可以通过配置数据源连接池来优化数据库的性能,利用SpringBoot的缓存支持来减少数据库访问的频率,以及通过合理使用异步处理、消息队列等技术提高系统对高并发请求的响应能力。 在系统安全方面,需要重点关注...

    学习java的第二个项目,面试技巧和基础进阶知识。.zip

    11. **数据库操作**:SQL基础,如CRUD操作,以及连接池的使用,如C3P0、HikariCP等。 12. **Spring框架**:如果项目涉及到Spring,那么你需要熟悉依赖注入(DI)、AOP(面向切面编程)以及Spring Boot和Spring MVC...

    兼容mono的 Mysql.Data.dll

    - 实现数据缓存和连接池,提高性能。 - 能够利用.NET的 LINQ to SQL 功能,简化数据库操作。 总的来说,"兼容mono的 Mysql.Data.dll"是为了让C#开发者能够在Mono平台上无阻碍地使用MySQL数据库,从而扩大.NET应用...

    Tomcat7集群扩展session集中管理,redis配置

    它提供了连接池、命令执行等基本操作。 2. **commons-pool-1.6.jar**:Apache Commons Pool是Java对象池实现,这里用于管理Jedis实例,提高性能和资源利用率。 3. **tomcat-redis-session-manager-1.1.jar**:这是...

    Hessian与spring整合

    但为了进一步优化性能,我们还可以考虑使用HTTP压缩、连接池等技术。 7. **安全考虑**:在实际应用中,我们需要对Hessian服务进行安全控制,如添加身份验证、授权和加密机制。Spring Security可以与Hessian整合,...

    用Java实现的SQL数据库系统

    例如,使用连接池(如C3P0、HikariCP)来复用数据库连接,减少建立和关闭连接的开销。 8. **安全性**:数据库系统必须保护数据的安全,包括认证、授权和加密。Java提供了安全管理器和SSL/TLS支持,可以帮助实现安全...

    SQL-tuning.rar_oracle

    当我们谈论SQL调优,尤其是在Oracle数据库环境中,我们指的是优化SQL查询,以提高其性能、减少资源消耗并提升整体系统效率。Oracle SQL调优是数据库管理员和开发人员日常工作中不可或缺的一部分。 在“SQL-tuning....

    NodeWithMongoDBConnection

    在实际应用中,通常会使用更高级的模式,如数据库连接池,以提高性能和管理多个并发连接。此外,还可以使用ORM(对象关系映射)工具,如Mongoose,来简化数据库操作并提供类型安全。 `NodeWithMongoDBConnection-...

    pnhs_alumni

    它可以处理各种Redis命令,并支持连接池、事务、发布/订阅等高级功能。安装Predis通常通过Composer,PHP的依赖管理工具,运行`composer require predis/predis`即可。 3. **Redis节点**:在Redis集群中,节点是构成...

Global site tag (gtag.js) - Google Analytics