1 / 12
文档名称:

JAVA java数据库连接池.doc

格式:doc   大小:69KB   页数:12页
下载后只包含 1 个 DOC 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

JAVA java数据库连接池.doc

上传人:xinshengwencai 2017/11/7 文件大小:69 KB

下载得到文件列表

JAVA java数据库连接池.doc

相关文档

文档介绍

文档介绍:JAVA数据库连接池
基本概念及原理
数据库连接池是为了解决数据库对象的共享出错问题。
实际就是建立一个缓冲池。
原理
预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从连接池中取出一个,使用完毕之后再放回去。
JDBC的API中没有提供连接池的方法。
连接池关键问题分析
使用线程同步来解决并发问题
使用一个单例模式的连接池管理类来解决连接多个不同数据库。具体方法:
在连接池管理类的唯一实例被创建时读取一个资源文件,其中资源文件中存放着多个数据库的url地址()、用户名()、密码()等信息。=:5000/tx_it,=yang,=yang321。
根据资源文件提供的信息,创建多个连接池类的实例,每一个实例都是一个特定数据库的连接池。连接池管理类实例为每个连接池实例取一个名字,通过不同的名字来管理不同的连接池。
使用资源文件来解决同一个数据库有多个用户使用不同的名称和密码访问的情况。具体方法:
资源文件中设置多个具有相同url地址,但具有不同用户名和密码的数据库连接信息。
可采用每一个事务独占一个连接来实现事务处理, 这种方法可以大大降低事务管理的复杂性。具体方法:
mit属性为false,mit或rollback方法来实现。
使用空闲池来解决连接池的分配与释放处理。具体办法:
把已经创建但尚未分配出去的连接按创建时间存放到一个空闲池中。
每当用户请求一个连接时,系统首先检查空闲池内有没有空闲连接:
如果有就把建立时间最长(通过容器的顺序存放实现)的那个连接分配给他(实际是先做连接是否有效的判断,如果可用就分配给用户,如不可用就把这个连接从空闲池删掉,重新检测空闲池是否还有连接)。
如果没有则检查当前所建连接池是否达到连接池所允许的最大连接数(maxConn),如果没有达到,就新建一个连接,如果已经达到,就等待一定的时间(timeout)。如果在等待的时间内有连接被释放出来就可以把这个连接分配给等待的用户,如果等待时间超过预定时间timeout,则返回空值(null)。
系统对已经分配出去正在使用的连接只做计数,当使用完后再返还给空闲池。
连接池的配置与维护
连接池中到底应该放置多少连接,才能使系统的性能最佳?
设置连接最小数(系统启动时连接池所创建的连接数)、最大数(使用连接池时所允许连接最大连接数目)
如何确保连接池中的最小连接数呢?
动态策略: 每隔一定时间就对连接池进行检测,如果发现连接数量小于最小连接数,则补充相应数量的新连接,以保证连接池的正常运转。
静态策略: 发现空闲连接不够时再去检查。
连接池的实现
连接池模型
DBConnectionPoolManager(
连接池管理外覆类(wrapper),符合单例模式)
DBConnectionPool(连接池内部类)
从连接池获取或创建可用连接;
public Connection getConnection()
使用完毕之后,把连接返还给连接池;
public synchronized void freeConnection(Connection con)
在系统关闭前,断开所有连接并释放连接占用的系统资源;
public synchronized void release()
还能够处理无效连接(原来登记为可用的连接,由于某种原因不再可用,如超时,通讯问题),并能够限制连接池中的连接总数不低于某个预定值和不超过某个预定值。
private int checkedOut;//已被分配出去的连接数
private int minConn;//连接池里连接的最小数量
private int maxConn;//连接池里允许存在的最大连接数
private String name; //为这个连接池取个名字,方便管理
应用示例:
import .*;
import .*;
import .*;
import ;
//建立DBConnectionManager
public class DBConnectionManager {
static private DBConnectionManager instance;
static private int clients;
private Vector drivers = new Vector();
private PrintWriter log;
private Hashtable pools = new Hashtable();
//

最近更新

2025年顺德职业技术学院单招职业适应性测试题.. 63页

2025年新人教版六年级语文上册期中测试卷及参.. 6页

2025年黄山职业技术学院单招职业技能测试题库.. 61页

标准个人租车协议书标准模板(八) 3页

2025年黑龙江省哈尔滨市单招职业倾向性测试题.. 64页

材料计算毕业论文 5页

机械制造企业成本控制管理论文 5页

本科生毕业论文撰写格式及打印要求 4页

2025年度安全生产责任保险合同协议模板3篇 53页

晚会结束语主持词 5页

新型洗电风扇指南说明书 4页

2025年幼儿小班健康活动教案爱清洁教案附教学.. 2页

2025年工商管理与市场营销个好 4页

推进油田外部项目物资保供工作的几点探讨 25页

招投标法律法规法考试试卷 6页

2025年寒假养老院社会实践心得 2页

2025年学雷锋主题班会教案优秀范文合集 6页

2025年妇科出科总结优选8篇 11页

2025年大学语文试卷 10页

建筑模型师求职简历模板建筑工程求职简历模板.. 7页

广播电视大学汉语言文学专业实践教学模式初探.. 6页

2025年国旗下的讲话珍惜每一分钟参考讲话 3页

2025年分类计数原理和分步计数原理 12页

2025年关于爱护地球的说明文作文 5页

2025年六年级数学上册期末测试卷 6页

全新个人把车租给公司租车协议 4页

最新部编版六年级道德与法治下册课程纲要 4页

射频消融术后护理常规 8页

舞蹈编导基本知识 4页

《园林绿化工程施工及验收规范》(CJJ82-2023).. 29页