连接池是创建和管理一个连接的缓冲池的技术,这些连接准备好被任何需要它们的线程使用。
优势好处:
1.减少连接创建时间
2.简化的编程模式
运作原理:
在实际应用开发中,特别是在WEB应用系统中,如果JSP、Servlet或EJB使用JDBC直接访问数据库中的数据,每一次数据访问请求都必须经历建立数据库连接、打开数据库、存取数据和关闭数据库连接等步骤,而连接并打开数据库是一件既消耗资源又费时的工作,如果频繁发生这种数据库操作,系统的性能必然会急剧下降,甚至会导致系统崩溃。数据库连接池技术是解决这个问题最常用的方法,在许多应用程序服务器(例如:Weblogic,WebSphere,JBoss)中,基本都提供了这项技术,无需自己编程,但是,深入了解这项技术是非常必要的。
数据库连接池技术的思想非常简单,将数据库连接作为对象存储在一个Vector对象中,一旦数据库连接建立后,不同的数据库访问请求就可以共享这些连接,这样,通过复用这些已经建立的数据库连接,可以克服上述缺点,极大地节省系统资源和时间。
具体的连接池:例
数据库连接池:
1.负责分配,管理和释放数据库连接。
2.允许应用程序重复使用一个现有的数据库连接,而不是在重新创建一个.
3.释放空闲时间超过最大空闲时间的数据库连接来避免因为没有释放数据库连接而引起的数据库连接遗漏。
4.能明显提高对数据库操作的性能。
数据库连接池就是保存了很多数据库连接对象的对象池。
数据库连接是一种关键的有限的昂贵的资源。
多用户的网页程序中体现的尤为突出。
一个数据库连接对象均对应一个物理数据库连接,每次操作都打开一个物理连接,使用完都关闭连接,这样造成系统的性能低下。
数据库连接池解决方案
在应用程序启动时建立足够的数据库连接,并将这些连接组成一个连接池(简单说:在一个“池”里放了好多半成品的数据库连接对象)·由应用程序动态地对池中的连接进行申请、使用和释放。
对于多于连接池中连接数的并发请求,应该在请求队列中排队等待。并且应用程序可以根据池中连接的使用率,动态增加或减少池中的连接数。
对于多于连接池中连接数的并发请求,应该在请求队列中排队等待。并且应用程序可以根据池中连接的使用率,动态增加或减少池中的连接数。
在java中开源的数据库连接池:
1.C3P0
2.Proxcool
3.jakarta DBCP
4.DDConnectionBroker
5.DBPool
6.XAPool
7.Primrose
8.SmartPool