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年开业领导致辞大全 7页

2025年度篮球馆运营安全管理服务合同 8页

2025年度科技创新债权投资合作协议 8页

2025年建筑工程试用期转正工作总结3篇 8页

2025年度离婚协议附带房地产项目开发权转让合.. 9页

2025年度研发团队岗位股权分配协议书 7页

版电子产品采购合同范文 6页

2025年度知识产权保护与知识产权战略布局合作.. 8页

2025年度男方抚养权保障的离婚协议及子女未来.. 7页

2025年实用临床预防指南解读 21页

2025年度电子商务企业人事代理及电商运营管理.. 8页

2025年度电商平台金融科技解决方案服务协议 9页

2025年度电力安全应急响应服务合同 8页

2025年度生物科技研发合伙投资协议书范例 9页

2025年度生物制药企业员工劳动聘用协议 8页

2025年度生态旅游商铺租赁与可持续发展合同 8页

2025年Brugada综合症诊断与治疗探讨 44页

2025年儿童早期高危信号精准识别 18页

2025年度生态修复工程简易承包合同 9页

2025年度现售商品房买卖合同(附智能家居配置.. 9页

2025年京都四疗法共识解读攻略 39页

2025年度环保设施建设劳务人工费支付合同 9页

2025年度环保节能设备公司干股分红及市场拓展.. 7页

2025年度环保污水处理设备供货合同集合 9页

2025年临床实验基础原理解析 17页

2025年中枢神经系统感染鉴别诊断与治疗方案 54页

2025年度环保产业用地及设施转让协议 9页

2025年度特色鱼种养殖合作合伙协议 9页

2025年度特色卤味店品牌加盟合作协议 9页

XX学校义务教育优质均衡发展创建实施方案范文.. 8页