动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Java教程 ]的信息

本月文章推荐
.体验 JDBC 2.0 规范的一些新东西.
.Java程序的脏数据问题.
.Java中通过代理服务器(proxy)访.
.JBuilder 7 WebLogic 6.X 详细配.
.给JAVA设计开发新手一些建议和意.
.阴阳历算法(转).
.P2P的Jxta解决之道.
.控制对类内部数据或函数成员访问.
.Java核心代码例程之:ProcessDem.
.jetspeeed简单开发文档.
.在 WebSphere AS 中使用 Web 服务.
.JMX前身JMAPI.
.实例讲解配置之——TOMCAT集群配.
.JBuilder应用技巧一则.
.提高Java应用程序属性持久化的方.
.Eclipse中集成Ant实现快速开发.
.由基本概念开始全面认识JAVA.
.安全的代价.
.java通过JDBC访问Oracle的2个异常.
.使用混淆器,保护你的java程序.

数据库连接池技术浅析

发表日期:2008-1-5 |



  数据库连接池技术浅析

一般情况下,在使用开发基于数据库的WEB程序时,传统的模式基本是按以下步骤:
   1. 在主程序(如Servlet、Beans)中建立数据库连接。
   2. 进行SQL操作,取出数据。
   3. 断开数据库连接。
   使用这种模式开发,存在很多问题。首先,我们要为每一次WEB请求(例如察看某一篇文章的内容)建立一次数据库连接,对于一次或几次操作来讲,或许你觉察不到系统的开销,但是,对于WEB程序来讲,即使在某一较短的时间段内,其操作请求数也远远不是一两次,而是数十上百次(想想全世界的网友都有可能在您的网页上查找资料),在这种情况下,系统开销是相当大的。事实上,在一个基于数据库的WEB系统中,建立数据库连接的操作将是系统中代价最大的操作之一。很多时候,可能您的网站速度瓶颈就在于此。
   其次,使用传统的模式,你必须去治理每一个连接,确保他们能被正确关闭,假如出现程序异常而导致某些连接未能关闭,将导致数据库系统中的内存泄露,最终我们将不得不重启数据库。
   针对以上问题,我们首先想到可以采用一个全局的Connection对象,创建后就不关闭,以后程序一直使用它,这样就不存在每次创建、关闭连接的问题了。但是,同一个连接使用次数过多,将会导致连接的不稳定,进而会导致WEB SERVER的频频重启。故而,这种方法也不可取。实际上,我们可以使用连接池技术来解决上述问题。首先,介绍一下连接池技术的基本原理。顾名思义,连接池最基本的思想就是预先建立一些连接放置于内存对象中以备使用:

   如图所示,当程序中需要建立数据库连接时,只须从内存中取一个来用而不用新建。同样,使用完毕后,只需放回内存即可。而连接的建立、断开都有连接池自身来治理。同时,我们还可以通过设置连接池的参数来控制连接池中的连接数、每个连接的最大使用次数等等。通过使用连接池,将大大提高程序效率,同时,我们可以通过其自身的治理机制来监视数据库连接的数量、使用情况等。下面我们以一个名为ConnectionPool的连接池为例来看看连接池的实现。先看看ConnectionPool的基本属性:
   m_ConnectionPoolSize:连接池中连接数量下限
   m_ConnectionPoolMax:连接池中连接数量上限
   m_ConnectionUseCount:一个连接的最大使用次数
   m_ConnectionTimeout:一个连接的最长空闲时间
   m_MaxConnections = -1:同一时间的最大连接数
   m_timer:定时器
   这些属性定义了连接池与其中的每个连接的有效状态值。连接池的自我治理,实际上就是通过定时的对每个连接的状态、连接的数量进行判定而进行相应操作。其治理流程如下:

通过上图,我们可以定义出ConnectionPool要完成治理所需要的基本接口:
public class ConnectionPool implements TimerListener{
   public boolean initialize() //连接池初始化
   public void destroy() //连接池的销毁
   public synchronized Java.sql.Connection getConnection() //取一个连接
   public synchronized void close() //关闭一个连接
   private synchronized void removeFromPool() //把一个连接从连接池中删除
   private synchronized void fillPool() //维护连接池大小
   public synchronized void TimerEvent() //定时器事件处理函数
}
   通过这几个接口,已经可以完成连接池的基本治理。在TimeEvent()函数中完成连接池的状态检验工作,fillPool()时连接池至少保持最小连接数。因为我们要保存每一个连接的状态,所以还需要一个数据库连接对象:
class ConnectionObject{
   public java.sql.Connection con; public boolean inUse; //是否被使用标志
   public long lastAccess; //最近一次开始使用时间
   public int useCount; //被使用次数
}
加入了ConnectionObject对象后,在ConnectionPool中操作的应该只是ConnectionObject,而其他进程需要的只是ConnectionObject的con属性,因此我们再加入一个类,作为其他进程获得与返回连接的接口: CLASS Conn{
   GetConnection(); //从连接池中取出一个有效连接
   CloseConnection(); //返回连接,此时并没有关闭连接,只是放回了连接池
   DestroyPool(); //销毁连接池
}
   最后我们的整个系统总的架构如下:

   通过上面的介绍,我们可以看出,连接池技术的要害就是其自身的治理机制,以上的治理流程只是本人一点见解,要害是想向大家介绍一种思路,在此基础上,您可以进一步完善连接池技术为您所用。
上一篇:用ActionForm一次获取表单所有参数 人气:635
下一篇:数据结构――栈、队列和树(Java) 人气:1043
浏览全部Java的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-10-10 企业网站智能管理系统(TZIMS) v6
2008-10-10 拓文asp.net网站内容管理系统 v6
2008-10-10 动网论坛PHP版 v2.0++ Build 081
2008-10-10 免费时代CMS v5.0
2008-10-10 wodig第四季中文DIGG社区 v4.1 b
2008-10-10 老Y文章管理系统 v2.2 bulid 081
2008-10-10 魔法盒动感相册 ASP+SQL版 v2.0
2008-10-10 Asoft签到管理系统 v3.0 Pack1
2008-10-10 哥特人音乐网潮流留言本 v1.1
2008-10-11 联系人分组工具 v1.1 中文破解版
2008-10-11 FaceMelter变脸 v2.0 汉化破解版
2008-10-11 PathTracker道路跟踪仪 v1.2 破解
2008-10-11 Rooms手机聊天室 v0.6.7 破解版
2008-10-11 RemoteDesktop远程桌面 v1.0 破解
2008-10-11 ProRemote远程调音台 v1.0.1 破解
2008-10-11 PicShare照片共享 v1.0.0 破解版
2008-10-11 Photogene照片编辑器 v1.5 汉化破
2008-10-11 WriteRoom共享文档 v1.0 破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | js/vbs加密 | md5加密 | 进制转换 | UTF-8 转换工具 | Html转换js | Html转换asp | Html转换php | Html转换perl
实用工具:汉字翻译拼音 | 拼音字典 | 符号对照表 | 个税计算 | 实时汇率查询换算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 | 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵
SEO対策 中国語教室 ホームページ作成