版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、基于JAVA的数据库连接池的开发摘 要在基于JDBC的数据库实际应用开发中,对数据库连接的管理是一个重点也是一个难点,频繁对数据库的连接与关闭操作、多客户对数据库的并发访问,一定程度上决定了WEB系统的响应以及应用性能。使用数据库连接池方式能对数据库的连接进行管理和维护,上层应用程序通过数据库连接池使用数据库资源能提升系统性能,充分利用系统资源。文章通过介绍、分析数据库连接池工作的根本原理,了解目前流行的WEB效劳器在数据库连接池方面的使用现状后,总结一了些数据库连接池开发程序中容易忽略的问题。并在学习掌握了实现连接池的关键技术后给出了一个较为高效的连接池管理策略,在这种策略思想的指导下实际开
2、发出一个数据库连接池模块,使得上层应用通过本连接池访问数据库资源变得相对高效和容易,从实际上论证了这种设计方案的可行性。关键词:连接池;数据库;JDBC;并发访问Research and realization of the Database Connection Pool AbstractIn the practically application development of database based on JDBC, the management of database connection is a key point and also a difficulty. The resp
3、onse and performance of the WEB system are depended on frequently connecting, closing and multi-user accessing in a certain extent. Using the Database Connection Pool can provide management and maintenance for connections of the database. The upper applications may access the database recourse via t
4、he Database Connection Pool, in order to upgrade system performance and fully utilize the system recourse. This article summarizes some issues which are easily ignored in the application development of the Database Connection Pool by the way of introducing and analyzing the basal working principles
5、of the Database Connection Pool ,comprehending the using actuality of the Database Connection Pool on the popular WEB servers. Besides, I established a comparatively highly effective policy of the Connection Pool management after having learned and comprehended key technique of implementing the Conn
6、ectivity Pool, and actually had developed a Database Connection Pool module under the guidance of that policy, causing the access of system resource by the upper applications via current Connectivity Pool becoming relatively highly effective and easy, demonstrated the feasibility of this design proj
7、ect in practice.Key words: Database Connection Pool; Database; JDBC; Concurrence access目 录论文总页数:22页 TOC o 1-3 h z u HYPERLINK l _Toc169603241 1引言 PAGEREF _Toc169603241 h 1 HYPERLINK l _Toc169603242 课题背景 PAGEREF _Toc169603242 h 1 HYPERLINK l _Toc169603243 连接池的主要作用 PAGEREF _Toc169603243 h 1 HYPERLINK
8、l _Toc169603244 目前流行的web效劳器数据库连接池方面使用现状 PAGEREF _Toc169603244 h 1 HYPERLINK l _Toc169603245 DHCP介绍 PAGEREF _Toc169603245 h 2 HYPERLINK l _Toc169603246 Poolman介绍 PAGEREF _Toc169603246 h 2 HYPERLINK l _Toc169603247 C3P0介绍 PAGEREF _Toc169603247 h 2 HYPERLINK l _Toc169603248 其他连接池自写连接池 PAGEREF _Toc16960
9、3248 h 2 HYPERLINK l _Toc169603249 2相关理论根底 PAGEREF _Toc169603249 h 3 HYPERLINK l _Toc169603250 数据库概述 PAGEREF _Toc169603250 h 3 HYPERLINK l _Toc169603251 数据库连接池的根本原理 PAGEREF _Toc169603251 h 3 HYPERLINK l _Toc169603252 连接池中的关键技术 PAGEREF _Toc169603252 h 4 HYPERLINK l _Toc169603253 连接池的分配与释放 PAGEREF _To
10、c169603253 h 4 HYPERLINK l _Toc169603254 连接池的维护 PAGEREF _Toc169603254 h 5 HYPERLINK l _Toc169603255 3系统总体设计思想及方案 PAGEREF _Toc169603255 h 5 HYPERLINK l _Toc169603256 连接池中的关键类设计 PAGEREF _Toc169603256 h 6 HYPERLINK l _Toc169603257 连接池中的管理机制 PAGEREF _Toc169603257 h 7 HYPERLINK l _Toc169603258 实现一个连接池的其他
11、问题 PAGEREF _Toc169603258 h 8 HYPERLINK l _Toc169603259 事务处理 PAGEREF _Toc169603259 h 8 HYPERLINK l _Toc169603260 封装 PAGEREF _Toc169603260 h 9 HYPERLINK l _Toc169603261 并发 PAGEREF _Toc169603261 h 9 HYPERLINK l _Toc169603262 连接池的关闭 PAGEREF _Toc169603262 h 9 HYPERLINK l _Toc169603263 4具体的设计流程和实现 PAGEREF
12、 _Toc169603263 h 10 HYPERLINK l _Toc169603264 连接池的建立 PAGEREF _Toc169603264 h 10 HYPERLINK l _Toc169603265 连接池的管理 PAGEREF _Toc169603265 h 12 HYPERLINK l _Toc169603266 连接池的关闭 PAGEREF _Toc169603266 h 14 HYPERLINK l _Toc169603267 连接池的测试 PAGEREF _Toc169603267 h 15 HYPERLINK l _Toc169603268 5系统测试问题总结 PAGE
13、REF _Toc169603268 h 15 HYPERLINK l _Toc169603269 连接池的泄露问题 PAGEREF _Toc169603269 h 15 HYPERLINK l _Toc169603270 产生现象 PAGEREF _Toc169603270 h 15 HYPERLINK l _Toc169603271 解决方法 PAGEREF _Toc169603271 h 16 HYPERLINK l _Toc169603272 多数据库效劳器问题 PAGEREF _Toc169603272 h 17 HYPERLINK l _Toc169603273 结 论 PAGERE
14、F _Toc169603273 h 19 HYPERLINK l _Toc169603274 参考文献 PAGEREF _Toc169603274 h 20 HYPERLINK l _Toc169603275 致 谢 PAGEREF _Toc169603275 h 21 HYPERLINK l _Toc169603276 声 明 PAGEREF _Toc169603276 h 22引言课题背景随着信息技术的高速开展与广泛应用,数据库技术在信息技术领域中的位置越来越重要。传统的开发模式是:首先在主程序如Servlet、Beans中建立数据库连接;然后进行SQL操作,对数据库中的对象进行查询、修改
15、和删除等;最后断开数据库连接。使用这种开发模式,对于一个简单的数据库应用,由于数据库的访问不是很频繁,只需要在访问数据库时创立一个连接,用完后就关闭它,这样做不会明显增大系统的开销。但是对于一个复杂的数据库应用,情况就完全不同了,尤其是大型电子商务网站,同时可能有几百人甚至几千人在线。在这种情况下,用户操作频繁的建立、关闭数据库,会极大的降低系统的性能,增大系统的开销,迫使网站的响应速度下降,严重的甚至会造成效劳器的崩溃。针对这些突出问题,采用运行速度更快、数据库访问效率更高的数据库连接池技术,以提高系统的运行效率将是至关重要的,因此本文提出了一种基于数据库连接池技术的有效解决方法。以加强对数
16、据库操作的性能,改善资源使用率,提高应用程序的响应能力。连接池的主要作用一个应用系统,同时有几百人甚至几千人频繁的进行数据库连接操作势必占用很多的系统资源,严重的甚至会造成效劳器的崩溃。对于每一次数据库连接,使用完后都得断开。否那么,如果程序出现异常而未能关闭,将会导致数据库系统中的内存泄漏,最终将不得不重启数据库。还有,如果不能控制被创立的连接对象数,系统资源会被毫无顾及的分配出去,连接过多也可能导致内存泄漏,效劳器崩溃。针对这些突出问题,因此提出了一种基于数据库连接池技术的有效解决方法。简而言之,数据库连接池主要作用是负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连
17、接,而不再是重新建立一个;释放空闲时间超过最大空闲时间的数据库连接来防止因为没有释放数据库连接而引起的数据库连接遗漏。目前流行的web效劳器数据库连接池方面使用现状由于JDBC的API中没有提供连接池的方法。一些大型的WEB应用效劳器如WebLogic、WebSphere等都自带有连接池。不同的是,tomcat并没有自已开发连接池,而是集成的apache的另外一个开源工程DBCP连接池。BEA的WebLogic自身带有一个连接池,这个连接池无法与WebLogic别离,但是也必须有其第三方的专用类方法支持连接池的用法,而不需要用户再去写一个连接池。以下是一些第三方连接池:DHCP介绍DBCP应A
18、pache的Jakarta组织开发,是目前使用较为广泛的一个连接池,一是因为tomcat自带的就是这个连接池,二是因为开源免费。由于其使用的稳定性不是很好,著名的开源工程hibernate不再提供对它的支持。DBCP局部参数说明如下:dataSource:要连接的 dataSource (通常我们不会定义在 server.xml)。defaultAutoCommit:对于事务是否 autoCommit, 默认值为 true。defaultReadOnly:对于数据库是否只能读取, 默认值为 false。driverClassName:连接数据库所用的 JDBC Driver Class。max
19、Active:最大连接数据库连接数,设 0 为没有限制。maxIdle:最大等待连接中的数量,设 0 为没有限制。maxWait:最大等待秒数, 单位为 ms, 超过时间会出错误信息。password:登陆数据库所用的密码。url:连接数据库的 URL。username:登陆数据库所用的帐号。validationQuery:验证连接是否成功, SQL SELECT 指令至少要返回一行。removeAbandoned:是否自我中断, 默认是 false。removeAbandonedTimeout:几秒后会自我中断, removeAbandoned 必须为 true。logAbandoned:是
20、否记录中断事件, 默认为 false。Poolman介绍Poolman连接池前几年应用较广泛,现在应用相对较少。配置步骤主要是先在/工程名称/web-Inf/下参加一个jar包,然后配置一个xml文件,文件属性类似于DBCP,最后在程序中写出调用该连接池的方法。C3P0介绍C3P0是一个开放源代码的JDBC连接池,它在lib目录中与Hibernate一起发布,包括了实现JDBC3.0和JDBC2.0扩展标准说明的Connection 和Statement 池的DataSource 对象。自从hibernate自带了c3p0以后,c3p0很快就受到了广阔程序员的认可,其性能上来说比DBCP要好的
21、多。其他连接池自写连接池有些程序员喜欢自己写连接池,建议不用这样的方法,因为连接池的管理较为复杂,自己写常出现各种各样的错误,推荐使用有成熟技术的连接池,同时也方便系统的移植。相关理论根底数据库概述数据库,顾名思义,是存入数据的仓库。只不过这个仓库是在计算机存储设备上的,而且数据是按一定格式存放的。 当人们收集了大量的数据后,应该把它们保存起来进入近一步的处理,进一步的抽取有用的信息。当年人们把数据存放在文件柜中,可现在随着社会的开展,数据量急剧增长,现在人们就借助计算机和数据库技术科学的保存大量的数据,以便能更好的利用这些数据资源。 要是下定义的话,就应该是:指长期储存在计算机内的、有组织的
22、、可共享的数据集合。数据库包含关系数据库、面向对象数据库及新兴的XML数据库等多种,目前应用最广泛的是关系数据库,假设在关系数据库根底上提供局部面向对象数据库功能的对象关系数据库。在数据库技术的早期还曾经流行过层次数据库与网状数据库,但这两类数据库目前已经极少使用。数据库连接池的根本原理建立“缓冲存储池,是数据库连接池的根本设计思想。这种技术类似于CPU 中的Cache 技术,将预先设定好的数据库连接放入该缓冲池中,当要建立数据库连接操作时,便从池中取出一个连接,使用完毕后再将其放回。这样就到达了连接复用的目的,应用程序重复使用一个数据库连接,在多层结构的应用程序中通过连接池技术可以使系统的性
23、能明显得到提到。最为关键的是,该方法防止了对数据库连接的频繁建立、关闭,减小了系统开销,提高了响应速度。我们可以通过设定连接池最大连接数来防止系统无尽的与数据库连接。更为重要的是我们可以通过连接池的管理机制监视数据库的连接的数量使用情况,为系统开发测试及性能调整提供依据。数据库连接池属于应用程序对底层的调用,用户并发访问应用程序时会提交访问请求,然后通过线程来处理这些请求,并向连接池申请一个对数据库操作的连接,操作完毕后将连接释放。应用程序调用连接池连接的根本工作原理如下列图所示:图1 连接池的调用基于以上原理,连接池的建立会在后面章节中做具体描述。为了方便理解,连接池以JSP页面形式将最大连
24、接数的设置、连接池的使用、超时等待、连接池的关闭等情况展示出来,给用户一个更为直观的感受。连接的调用原理如下列图所示:取得连接释放连接图2 建立数据库连接从图中可以看出,当程序JSP、Servlet、JavaBean中需要数据库连接时,只需从内存中取出一个来,并将这个取得的连接参加Vector中,而不用新建连接;使用完毕后放回内存中,并将Vector中的已用连接删除。连接池中的关键技术连接池的分配与释放连接池的分配与释放技术对系统的性能有很大的影响。合理的分配与释放,可以提高连接的复用度,从而降低建立新连接的开销,同时还可以加快用户的访问速度。对于连接的管理。每当用户请求一个连接时,系统首先检
25、查连接池内有没有空闲连接。如果有就把建立时间最长通过容器的顺序存放实现的那个连接分配给他实际是先做连接是否有效的判断,如果可用就分配给用户,假设不可用就把这个连接删掉,重新检测是否还有连接;如果检查到当前所开连接池没有到达连接池所允许的最大连接数maxConn,就新建一个连接,如果已经到达,就等待一定的时间timeout。如果在等待的时间内有连接被释放出来就可以把这个连接分配给等待的用户,如果等待时间超过预定时间timeout,那么返回空值null。系统对已经分配出去正在使用的连接只做计数。连接池的维护数据库连接池到底要放置多少个连接,这是个配置策略。为了使系统的性能到达最正确状态,连接池中的
26、连接数的设定显得尤为重要,我们采用设置最大连接数maxConn和最小连接数minConn的方式来解决这一问题。所谓最大连接数,即连接池中允许连接的最大数目,然后,最大连接数的设定要通过具体的应用需求来给出一个连接池可以承受的最大连接数目的最正确点。如果应用程序向连接池请求的连接数超过最大连接数量时,这些请求将被参加到等待队列中,等待其他连接的释放后再来调用一空闲连接freeConn,这样可能会影响局部对数据库的操作。所谓最小连接数,即应用启动前,已经预先创立好的连接数。无论这些数据库连接是否被使用,连接池都将一直保证至少拥有这么多的连接数量。如果最小连接数过大,那么系统启动过程将变慢,假设应用
27、程序对数据库的访问量不大,过多的数据库连接资源将被浪费,但是系统启动后响应更快;如果过小系统启动将加快,但是最初使用的用户会因为连接池中没有足够的连接而会发送一个新的数据库连接请求,将不可防止的延缓执行速度。系统总体设计思想及方案数据库连接池技术的设计思想非常简单,先将数据库连接作为对象存储在一个Vector对象中,Vector 类可以实现可增长的对象“数组。Vector 的大小可以根据需要增大或缩小,以适应创立 Vector 后进行添加或移除项的操作。这里主要包含使用的连接nowConnections和未使用的连接freeConnections两个Vector类创立的对象,创立Vector对
28、象的方法如下:public DBConnectionPool(Vector connections) freeConnections = new Vector(); nowConnections = new Vector();当外部程序向数据库申请建立连接后,系统会调用nowConnections.add( )方法,此时已用连接计数器加1,相应的,调用move( )方法,此时空闲连接计数器减1,对于这样的引用计数法将会在后面的章节中具体描述。这样,不同的数据库访问请求就可以共享这些连接,并通过复用这些已经建立的数据库连接,克服传统开发模式对数据库操作的缺点。另外,采用超时判断timeout机制
29、,等待应用程序对连接的释放或者调用Connection.close方法主动释放连接,能极大地节省系统资源和用户等待时间。而实现连接池时,当应用程序调用Connection.close( )试图去关闭数据库连接时,这时需要有一个通告给连接池实现模块,通告对当前的数据库物理连接DBConnectionPool 对象进行重用。为了使连接池实现模块能得到这种“通告,连接池实现模块必须实现ConnectionEventListener接口,而且同时需要注册成为DBConnectionPool对象的监听者。连接池实现模块接受到此通告后,不是真正意义上的物理关闭,而是将DBConnectionPool对象返
30、回到池中进行重用。从上面的介绍,可以看出连接池技术的关键就是其自身的管理机制,结合连接池工作的根本原理,通过下列图展现出一个连接池系统的总体设计框架。GetConnection()CloseConnection()建立数据库连接图3 总体设计框架连接池中的关键类设计一个连接池应用的设计,需要几个关键局部作为支撑,其中最为重要的是DBConnectionPool类和DBConnectionManager类,他们对连接的建立、管理、释放起决定性作用。大体作用列举如下:1、一个DBConnectionPool类,该类负责从连接池获取(或创立)连接、将连接返回给连接池、空闲连接的超时等待、系统关闭时释
31、放所有资源并关闭所有连接。2、一个DataSourceProviderServlet类,该类负责通过上下文环境读取配置文件后装载和注册JDBC驱动、数据库名等。3、一个DBConnectionManager类,该类负责按预先指定的最大连接池数连初始化连接池、创立DBConnectionPool对象provider、当所有的连接客户退出后,关闭全部连接。4、属性文件,该文件中包含了数据库驱动DriverName、数据库URL、数据库表空间名User、表空间密码Password、连接池最大连接数maxConnections。5、即为应用程序对连接池中的连接的调用和释放,应用程序退出后连接池的关闭。
32、将以上5个局部串连起来,即是本连接池的简单设计流程。首先应用程序向连接池申请连接,就需要通过DBConnectionPool类、DBConnectionManager类对连接池初始化,并且还需要DataSourceProviderServlet类的帮助读取文件中的属性,加载和注册JDBC驱动、数据库名等,连接池才能初始化成功。之后通过DBConnectionPool类监视、管理应用程序调用、释放的数据库连接,并通过该类的cp对象将连接使用情况反映在页面上。连接池管理程序得到某个连接,而其他线程就不会得到这个数据库连接了,此线程使用结束后,该线程将连接交还给连接池管理程序,以分配给其他等待连接的
33、请求线程。这里连接池充分利用Java的线程同步机理,使当前效劳线程处于等待状态,直至有空闲的连接出现。最后当应用程序退出时,通过DBConnectionManager类负责连接池的关闭。连接池中的管理机制应用程序开发中“三分技术、七分管理的思想在连接池的配置中同样得以表达,如何从连接池中取得连接,何时释放连接、如何释放连接等问题还需要为连接池配置更为复杂的管理机制,连接池流程的管理如下列图所示,这些属性定义了连接池与其中每个连接的有效状态值。连接池的自我管理,实际上就是通过定时的对每个连接的状态、连接的数量进行判断而进行相应操作。结束退出单个连接状态检查完毕定时触发否图4 连接池的管理事务处理
34、前面讨论的是关于使用数据库连接进行普通的数据库访问。对于事务处理,情况就变得比拟复杂。因为事务本身要求原那么性的保证,此时就要求对于数据库的操作符合要么全部完成,要么什么都不做。如果简单的采用上述的连接复用的策略,就会发生问题,因为没有方法控制属于同一个事务的多个数据库操作方法的动作,可能这些数据库操作是在多个连接上进行的,并且这些连接可能被其他非事务方法复用。Connection本身具有提供了对于事务的支持,可以通过设置Connection的AutoCommit属性为false,显式的调用 commit或rollback方法来实现。但是要平安、高效的进行连接复用,就必须提供相应的事务支持机制
35、。方法是:采用显式的事务支撑方法,每一个事务独占一个连接。这种方法可以大大降低对于事务处理的复杂性,并且又不会阻碍连接的复用。连接管理效劳提供了显式的事务开始、结束commit或rollback声明,以及一个事务注册表,用于登记事务发起者和事务使用的连接的对应关系,通过该表,使用事务的局部和连接管理局部就隔离开,因为该表是在运行时根据实际的调用情况动态生成的。事务使用的连接在该事务运行中不能被复用。在实现中,用户标识是通过使用者所在的线程来标识的。后面的所有对于数据库的访问都是通过查找该注册表,使用已经分配的连接来完成的。当事务结束时,从注册表中删除相应表项。封装从上面的论述可以看出,普通的数
36、据库方法和事务方法对于连接的使用分配、释放是不同的,为了便于使用,对外提供一致的操作接口,对连接进行了封装:普通连接和事务连接,并利用了Java中的强大的面向对象特性:多态。普通连接和事务连接均实现了一个DBConnection接口,对于接口中定义的方法,分别根据自己的特点作了不同的实现,这样在对于连接的处理上就非常的一致了。并发为了使连接管理效劳有更大的通用性,我们必须要考虑到多线程环境,即并发问题。在一个多线程的环境下,必须要保证连接管理自身数据的一致性和连接内部数据的一致性,在这方面Java提供很好的支持synchronized关键字,这样就很容易使连接管理成为线程平安的。对于并发访问,
37、所有的当前请求都将被连接池管理程序按顺序锁定。对请求线程的锁定是通过应用程序代码进行的,且请求数量可以很大,不必担忧超出缓冲容量限制。一旦将连接交还给连接池,该连接将由连接池管理程序分配给其他锁定的请求。当有很多数据库请求并超出了连接池中连接的数目时,只有先发出数据库请求的线程获得连接来访问数据库,其他连接暂时处于等待的锁定状态,当线程完成数据库操作并释放连接后,被释放的连接将按顺序由其他线程获得,这样就可以大大节省效劳器的资源。连接池的关闭很多的连接池都要求用户通过其规定的方法获取数据库的连接,这一点我们可以理解,毕竟目前所有的应用效劳器取数据库连接的方式都是这种方式实现的。但是另外一个共同
38、的问题是,它们同时不允许使用者显式的调用Connection.close()方法,而需要用其规定的一个方法来关闭连接。这种做法有两个缺点: 第一:改变了用户使用习惯,增加了用户的使用难度。使用者在用完数据库连接后通常是直接调用连接的close方法来释放数据库资源。第二:使连接池无法对之中的所有连接进行独占控制。由于连接池不允许用户直接调用连接的close方法,一旦使用者在使用的过程中由于习惯问题直接关闭了数据库连接,那么连接池将无法正常维护所有连接的状态。具体的设计流程和实现连接池的建立连接池的管理连接池管理策略是连接池机制的核心。当连接池建立后,如何对连接池中的连接进行管理,解决好连接池内连
39、接的分配和释放,对系统的性能有很大的影响。连接的合理分配、释放可提高连接的复用,降低了系统建立新连接的开销,同时也加速了用户的访问速度。下面介绍连接池中连接的分配、释放策略。连接池的分配、释放策略对于有效复用连接非常重要。就一般情况而言,当客户释放数据库连接时,先判断该连接的引用次数是否超过了规定值,如果超过就删除该连接,并判断当前连接池内总的连接数是否小于minConn最小连接数,假设小于就将连接池充满;如果没超过就将该连接标记为开放状态,可供再次复用。可以看出正是这套策略保证了数据库连接的有效复用,防止频繁地建立、释放连接所带来的系统资源开销。我们采用的方法是一个很有名的设计模式:Refe
40、rence Counting引用记数。该模式在复用资源方面应用的非常广泛,把该方法运用到对于连接的分配释放上,为每一个数据库连接,保存一个引用记数,用来记录该连接的使用者的个数。具体的实现方法是:public synchronized Connection getConnection(int TimeOut) Connection con = null; if (freeConnections.size() = 0) System.out.println(连接失败,由于数据库连接池中无可用连接!请等待!); try new DBConnectionManager().closeAll(); c
41、atch (Exception ex) ex.printStackTrace(); return con; else Connection temp = (Connection) freeConnections.firstElement(); freeConnections.remove(temp); nowConnections.add(temp); return temp; 当应用程序向数据库发起连接请求时,会检查连接池中是否存在空闲的连接。如果存在空闲的连接,连接池那么把空闲连接分配给客户,并将该连接做相应处理,即标记为正在使用的连接,并将引用计数加1。如果不存在空闲连接,那么检查连接池
42、里的连接数是否已经到达了最大连接数maxConn,假设没有到达就为应用程序创立一个新的连接;假设到达了最大连接数,那么就需要等待连接的释放,等待连接的释放时间是由系统中预先定义好的一个超时参数Timeout来做判断。如果在超时等待TimeOut后仍没有可用的空间连接,程序上便会返回一个null值,同时抛出无空闲连接的异常给用户。public void TimeOut(int TimeOut, Connection con) try Thread t = new Thread(); t.start(); t.run(); t.wait(TimeOut); closeConnection(con)
43、; t.destroy(); catch (Exception ex) ex.printStackTrace(); 已用连接计数器的问题交由JSP页面中的循环来处理,每当应用程序申请一个连接时,计数器便会循环一次,局部实现代码如下:for (int i = 0; i cp.getNowConnections().size(); i+) out.println(连接名称 + (i + 1) + : + cp.getNowConnections().get(i) + ); con = (Connection)cp.getNowConnections().get(0); 对于未用连接的处理与已用连接
44、类似,局部实现代码如下:for (int j = 0; j cp.getFreeConnections().size(); j+) out.println(未用连接名称 + (j + 1) + : + cp.getFreeConnections().get(j) + ); 连接池的调用如下列图所示,假设连接已分配完毕,系统提示等待连接释放。图6 连接的调用连接池的关闭当应用程序退出时,通过调用closeAll方法来关闭连接池中的连接,此时应把在连接池建立时向数据库申请的连接对象统一归还给数据库即关闭所有数据库连接。public void closeAll() try if (rs != nul
45、l) rs.close(); if (smt != null) smt.close(); if (psmt != null) psmt.close(); if (con != null) provider.closeConnection(con); catch (Exception e) e.printStackTrace(); 连接池的测试对于一个好的连接池,性能显得尤为重要。性能不仅仅表达的是对数据库操作的处理速度还有连接池自身的稳定性。默认自带的数据库连接池c3p0快,但是稳定性却不如它,并发用户过多常常会自动断开连接。通过对本连接池的测试发现,有连接池的时候对数据库的操作要比没有连接池
46、的时候快3-5秒。一般数据库连接池采用DBCP作为连接池时,默认的初始化为50个,速度不会有太大问题。正常情况下,系统没问题,压力测试从10个并发开始,每一次增量是增加10个并发,至200-400并发用户将成为一个重要节点,性能的优越能得以表达。而本连接池没有经过压力测试,多用户的并发访问时其稳定性还有待验证。系统测试问题总结连接池的泄露问题产生现象当系统访问量较大时,会出现连接池连接数居高不下的情况,如果在关闭数据库连接的过程中发生错误会导致他们不再会被重用。这就叫做“数据库连接池泄漏。这将会最终导致web应用程序数据库连接失败。甚至造成连接池崩溃,从而无法进行数据交互,效劳器当机。解决方法
47、常见的程序错误写法有以下两种:1、当连接执行数据库操作出错时,未执行数据库关闭。Connection conn = DbUtil.getConnection();./执行数据库操作DbUtil.closeConnection();在以上代码中,如果执行数据库操作过程中,出现异常,系统从出现异常处停止,不再执行下面的代码,造成数据库连接池无法回收,连接泄露的情况。正确的代码写法应如下:TryConnection conn = DbUtil.getConnection();./执行数据库操作catch(Exception e)finallyDbUtil.closeConnection(); /异常
48、处理后必须处理的方法。这样将保证了在执行数据库操作过程中即使出现异常,也将能够执行数据库连接池的回收。2、在连接中嵌套数据库连接,如下:TryConnection conn = DbUtil.getConnection();doMethodA()/执行数据库操作catch(Exception e)finallyDbUtil.closeConnection();Public void doMethodA()./再次翻开数据库进行操作在上面的例子中,当调用方法doMethodA时,在方法内部又翻开了一个数据库连接,这时造成同一线程中翻开了两个连接,如果不注意,很有可能就翻开了更多的连接,以至于成为
49、系统性能的瓶颈。多数据库效劳器问题如今在一个应用系统中,一般可能不只访问一个数据库,有时会访问两个或是多个数据库,各个数据库的数据必须融会到同一个业务逻辑中,否那么就成为一个个低价值的数据孤岛,这时就需用到多数据源。在一个应用系统中,一般会有一个数据源应用较多,其它数据源应用较少,我们把应用较多的数据源定义为主数据源,其它数据源定义为从数据源。我们为每一个数据源定义一个名称,在应用系统中根据该名称定向到数据源。在应用中,我们定义一个静态Hashtable对数据源进行保存。下面给出一个方法:/* * 数据源hash表 */ private static final Hashtable dsHas
50、h = new Hashtable();用户在调用数据源时,首先从hash中查询该数据源,如果存在,直接返回,如果不存在,那么初始化DataSource,并放入hash中,再返回。注意:这儿用到了同步,以防止同一数据源初始化两次。/* * 初始化datasource * * param DB_NAME */ private static synchronized DataSource init(String DB_NAME) DataSource ds1 = (DataSource) dsHash.get(DB_NAME); if (ds1 = null) try Context initCtx = new In
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024离婚双方的共同债权债务处理合同
- 2024苗木种植与园林苗木种植基地规划与建设劳务分包协议3篇
- 2024版活动场地使用合同范本
- 2025年度生态农业园承包合同格式规范4篇
- 2024镍矿国际贸易法律事务咨询服务合同3篇
- 2025年度新能源车辆代理记账与补贴申请合同4篇
- 2025年度文化产业发展总经理聘用协议3篇
- 《蒸汽锅炉维护与管理》课件
- 2025年度个人二手房交易反担保合同规范4篇
- 2025年度博物馆展览馆日常保洁与文物保护合同4篇
- 2024年桂林中考物理试卷
- DL∕T 5362-2018 水工沥青混凝土试验规程
- (正式版)JC∕T 60023-2024 石膏条板应用技术规程
- DL-T5054-2016火力发电厂汽水管道设计规范
- (权变)领导行为理论
- 2024届上海市浦东新区高三二模英语卷
- 家用电器可靠性与寿命预测研究
- 中考语文二轮复习:诗歌鉴赏系列之边塞军旅诗(知识点+方法+习题)
- 2024年智慧工地相关知识考试试题及答案
- 五年级上册脱式计算练习300题及答案
- 健康产业园策划方案
评论
0/150
提交评论