欢迎来到天天文库
浏览记录
ID:10374977
大小:48.50 KB
页数:2页
时间:2018-07-06
《基于jdbc的数据库连接池技术的研究与应用论文》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、基于JDBC的数据库连接池技术的研究与应用论文摘要本文介绍了Java访问数据库的原理及其存在的问题,提出了解决办法-数据库连接池,并对其关键问题进行了分析,构建了一个简便易用的连接池并结合当前热门技术Servlet说明了其如何在开发时使用。关键词JDBC,Jsp/Servlet,数据库连接池,多数据库服务器和多用户,多线程1引言近年来Intra建网技术的飞速发展和在世界范围内的迅速普及,计算机应用程序已从传统的桌面应用转到anager)。连接池类是对某一数据库所有连接的“缓冲池”,主要实现以下功能:①从连接池获取或创建可用连接;②使用完毕之
2、后,把连接返还给连接池;③在系统关闭前,断开所有连接并释放连接占用的系统资源;④还能够处理无效连接(原来登记为可用的连接,由于某种原因不再可用,如超时,通讯问题),并能够限制连接池中的连接总数不低于某个预定值和不超过某个预定值。连接池管理类是连接池类的外覆类(plementsTimerListener{privateintcheckedOut;//已被分配出去的连接数privateArrayListfreeConnections=neinConn;//连接池里连接的最小数量privateintmaxConn;//连接池里允许存在的最大连接数
3、privateStringname;//为这个连接池取个名字,方便管理privateStringpassertimer;//定时器publicDBConnectionPool(Stringname,StringURL,Stringuser,StringpassaxConn)//公开的构造函数publicsynchronizedvoidfreeConnection(Connectioncon)//使用完毕之后,//把连接返还给空闲池publicsynchronizedConnectiongetConnection(longtimeout)//
4、得到一个连接,//timeout是等待时间publicsynchronizedvoidrelease()//断开所有连接,释放占用的系统资源privateConnectionneerEvent()//定时器事件处理函数}publicclassDBConnectionManager{staticprivateDBConnectionManagerinstance;//连接池管理类的唯一实例staticprivateintclients;//客户数量privateArrayListdrivers=nee/value的形式存取连接池//对象的名字
5、及连接池对象staticsynchronizedpublicDBConnectionManagergetInstance()//如果唯一的//实例instance已经创建,直接返回这个实例;否则,调用私有构造函数,创//建连接池管理类的唯一实例privateDBConnectionManager()//私有构造函数,在其中调用初始化函数init()publicvoidfreeConnection(Stringname,.freele是一个连接池对象的名字publicConnectiongetConnection(Stringname)//从
6、名字为name的连接池对象//中得到一个连接publicConnectiongetConnection(Stringname,longtime)//从名字为name//的连接池对象中取得一个连接,time是等待时间publicsynchronizedvoidrelease()//释放所有资源privatevoidcreatePools(Propertiesprops)//根据属性文件提供的信息,创建//一个或多个连接池privatevoidinit()//初始化连接池管理类的唯一实例,由私有构造函数调用privatevoidloadDriv
7、ers(Propertiesprops)//装载数据库驱动程序}5.3连接池使用上面所实现的连接池在程序开发时如何应用到系统中呢?下面以Servlet为例说明连接池的使用。Servlet的生命周期是:在开始建立servlet时,调用其初始化(init)方法。之后每个用户请求都导致一个调用前面建立的实例的service方法的线程。最后,当服务器决定卸载一个servlet时,它首先调用该servlet的destroy方法。根据servlet的特点,我们可以在初始化函数中生成连接池管理类的唯一实例(其中包括创建一个或多个连接池)。如:public
8、voidinit()throgr=DBConnectionManager.getInstance();}然后就可以在service方法中通过连接池名称使用连接池,执行数据库操作。
此文档下载收益归作者所有