JAVAjava数据库连接池.doc

JAVAjava数据库连接池.doc

ID:50826577

大小:48.00 KB

页数:11页

时间:2020-03-15

JAVAjava数据库连接池.doc_第1页
JAVAjava数据库连接池.doc_第2页
JAVAjava数据库连接池.doc_第3页
JAVAjava数据库连接池.doc_第4页
JAVAjava数据库连接池.doc_第5页
资源描述:

《JAVAjava数据库连接池.doc》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、JAVA数据库连接池l基本概念及原理n数据库连接池是为了解决数据库对象的共享出错问题。n实际就是建立一个缓冲池。n原理预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从连接池中取出一个,使用完毕之后再放回去。nJDBC的API中没有提供连接池的方法。l连接池关键问题分析n使用线程同步来解决并发问题n使用一个单例模式的连接池管理类来解决连接多个不同数据库。具体方法:u在连接池管理类的唯一实例被创建时读取一个资源文件,其中资源文件中存放着多个数据库的url地址()、用户名()、密码()等信息。如tx.url=172

2、.21.15.123:5000/tx_it,tx.user=yang,tx.password=yang321。u根据资源文件提供的信息,创建多个连接池类的实例,每一个实例都是一个特定数据库的连接池。连接池管理类实例为每个连接池实例取一个名字,通过不同的名字来管理不同的连接池。n使用资源文件来解决同一个数据库有多个用户使用不同的名称和密码访问的情况。具体方法:u资源文件中设置多个具有相同url地址,但具有不同用户名和密码的数据库连接信息。n可采用每一个事务独占一个连接来实现事务处理,这种方法可以大大降低事务管理的复杂性。具体方

3、法:uConnection类可以通过设置Connection的AutoCommit属性为false,然后显式的调用commit或rollback方法来实现。n使用空闲池来解决连接池的分配与释放处理。具体办法:u把已经创建但尚未分配出去的连接按创建时间存放到一个空闲池中。u每当用户请求一个连接时,系统首先检查空闲池内有没有空闲连接:l如果有就把建立时间最长(通过容器的顺序存放实现)的那个连接分配给他(实际是先做连接是否有效的判断,如果可用就分配给用户,如不可用就把这个连接从空闲池删掉,重新检测空闲池是否还有连接)。l如果没有则

4、检查当前所建连接池是否达到连接池所允许的最大连接数(maxConn),如果没有达到,就新建一个连接,如果已经达到,就等待一定的时间(timeout)。如果在等待的时间内有连接被释放出来就可以把这个连接分配给等待的用户,如果等待时间超过预定时间timeout,则返回空值(null)。u系统对已经分配出去正在使用的连接只做计数,当使用完后再返还给空闲池。n连接池的配置与维护u连接池中到底应该放置多少连接,才能使系统的性能最佳?l设置连接最小数(系统启动时连接池所创建的连接数)、最大数(使用连接池时所允许连接最大连接数目)u如何确

5、保连接池中的最小连接数呢?l动态策略:每隔一定时间就对连接池进行检测,如果发现连接数量小于最小连接数,则补充相应数量的新连接,以保证连接池的正常运转。l静态策略:发现空闲连接不够时再去检查。l连接池的实现n连接池模型uDBConnectionPoolManager(连接池管理外覆类(wrapper),符合单例模式)luDBConnectionPool(连接池内部类)l从连接池获取或创建可用连接;publicConnectiongetConnection()l使用完毕之后,把连接返还给连接池;publicsynchronize

6、dvoidfreeConnection(Connectioncon)l在系统关闭前,断开所有连接并释放连接占用的系统资源;publicsynchronizedvoidrelease()l还能够处理无效连接(原来登记为可用的连接,由于某种原因不再可用,如超时,通讯问题),并能够限制连接池中的连接总数不低于某个预定值和不超过某个预定值。privateintcheckedOut;//已被分配出去的连接数privateintminConn;//连接池里连接的最小数量privateintmaxConn;//连接池里允许存在的最大连接数

7、privateStringname;//为这个连接池取个名字,方便管理应用示例:importjava.io.*;importjava.sql.*;importjava.util.*;importjava.util.Date;//建立DBConnectionManagerpublicclassDBConnectionManager{staticprivateDBConnectionManagerinstance;staticprivateintclients;privateVectordrivers=newVector();p

8、rivatePrintWriterlog;privateHashtablepools=newHashtable();//返回唯一的实列staticsynchronizedpublicDBConnectionManagergetInstance(){if(instance==null){in

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。