数据库连接池简介

数据库连接是一种关键的有限的昂贵的资源,这一点在多用户的网页应用程序中体现得尤为突出。对数据库连接的管理能显著影响到整个应用程序的伸缩性和健壮性,影响到程序的性能指标。数据库连接池>数据库连接池正是针对这个问题提出来的。

数据库连接池>数据库连接池负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而再不是重新建立一个;释放空闲时间超过最大空闲时间的数据库连接来避免因为没有释放数据库连接而引起的数据库连接遗漏。这项技术能明显提高对数据库操作的性能。

数据库连接池>数据库连接池在初始化时将创建一定数量的数据库连接放到连接池中,这些数据库连接的数量是由最小数据库连接数来设定的。无论这些数据库连接是否被使用,连接池都将一直保证至少拥有这么多的连接数量。连接池的最大数据库连接数量限定了这个连接池能占有的最大连接数,当应用程序向连接池请求的连接数超过最大连接数量时,这些请求将被加入到等待队列中。数据库连接池>数据库连接池的最小连接数和最大连接数的设置要考虑到下列几个因素:

1) 最小连接数是连接池一直保持的数据库连接,所以如果应用程序对数据库连接的使用量不大,将会有大量的数据库连接资源被浪费;

2) 最大连接数是连接池能申请的最大连接数,如果数据库连接请求超过此数,后面的数据库连接请求将被加入到等待队列中,这会影响之后的数据库操作。

3) 如果最小连接数与最大连接数相差太大,那么最先的连接请求将会获利,之后超过最小连接数量的连接请求等价于建立一个新的数据库连接。不过,这些大于最小连接数的数据库连接在使用完不会马上被释放,它将被放到连接池中等待重复使用或是空闲超时后被释放。

在传统的两层结构中,客户端程序在启动时打开数据库连接,在退出程序时关闭数据库连接。这样,在整个程序运行中,每个客户端始终占用一个数据库连接,即使在大量没有数据库操作的空闲时间,如用户输入数据时,从而造成数据库连接的使用效率低下。

在三层结构模式中,数据库连接通过中间层的连接池管理。只有当用户真正需要进行数据库操作时,中间层才从连接池申请一个连接,数据库操作完毕,连接立即释放到连接池中,以供其他用户使用。这样,不仅大大提高了数据库连接的使用效率,使得大量用户可以共享较少的数据库连接,而且省去了建立连接的时间。

连接池的配置使用

数据库连接池>数据库连接池是应用服务器的一项基本功能,我们以Apusic Application Server为例,来说明JDBC连接池的配置使用。

Apusic JDBC连接池提供对多种数据库的支持,如Oracle、MS SqlServer、Sybase、Informix、DB2等。

Apusic JDBC连接池可以通过数据库本身的JDBC Driver连接到数据库,也可以通过JDBC-ODBC桥连接到数据库。下面我们以Oracle为例说明如何配置连接池:

Oracle数据库的JDBC Driver包文件classes111.zip在/usr/oracle/jdbc/lib(假设oracle的安装目录是/usr/oracle)目录下,首先将classes111.zip加入到系统的CLASSPATH中。然后在apusic/config/apusic.conf(假设安装目录为apusic) 中作如下设置:

<SERVICE

CLASS="com.apusic.jdbc.PoolManager"

NAME="JdbcPool:name=jdbc/sample"

>

<ATTRIBUTE NAME="ExpirationTime" VALUE="300"/>

<ATTRIBUTE NAME="MinCapacity" VALUE="5"/>

<ATTRIBUTE NAME="URL" VALUE="jdbc:oracle:thin:@192.168.19.136:1521:orcl"/>

<ATTRIBUTE NAME="ConnectionProperties" VALUE="user=gtj,password=abc123"/>

<ATTRIBUTE NAME="DriverClassName" VALUE="oracle.jdbc.driver.OracleDriver" />

<ATTRIBUTE NAME="MaxCapacity" VALUE="30"/>

</SERVICE>

ExpirationTime: 超时时间,单位是秒。当一个数据库连接超过expirationTime设定时间不被使用

时,系统会自动关闭这个数据库连接。默认值为300秒

MinCapacity: 最小连接数

URL: 数据库的URL

ConnectionProperties: 连接属性,其中:user用户名,password密码

DriverClassName: JDBC驱动程序类名

MaxCapacity: 最大连接数

192.168.19.136: oracle所在计算机的IP地址。

调用连接池

我们以一个JSP程序为例,说明如何使用连接池。首先通过JNDI得到DataSource,再的得到连接Connection,如下例所示:

<html>

<head>

<title>Jsp sample</title>

</head>

<body>

<p>

<%@ page contentType="text/html;charset=gb2312" %>

<%@ page import="

java.sql.*,

javax.naming.*,

javax.sql.*

"%>

<%

try{

Context ctx = new InitialContext();

DataSource ds = (DataSource)ctx.lookup("jdbc/sample");

Connection con = ds.getConnection();

Statement stmt = con.createStatement();

ResultSet rs = stmt.executeQuery("select ENAME from EMP");

while(rs.next()){

out.println("<p>" + rs.getString(1));

}

rs.close();

stmt.close();

}catch(Exception e){

System.out.println("jsp:" + e.getMessage());

}finally{

try{

con.close();

}catch(Exception e1){}

}

%>

</body>

</html>


http://www.niftyadmin.cn/n/1100067.html

相关文章

HPUoj1031: 排序 [水题](结构体)

1031: 排序 [水题] 时间限制: 1 Sec 内存限制: 128 MB提交: 7 解决: 3[提交][状态][讨论版]题目描述 有若干个同学的成绩单&#xff0c;形式如下&#xff1a; 姓名 语文成绩 数学成绩 英语成绩 颜值 ... QAQ 59 59 59 100 ... ...... 现在我想把这些同学的…

目标检测光流法(二):opencv下的光流L-K算法

后续将简单介绍光流法的一些简单实现包&#xff0c;包括OpenCV下的光流算法与matlab下的光流算法。该节主要介绍opencv下的光流实现。 Opencv的光流实现由好几个方法可以&#xff08;也就是说有好几个函数可以用&#xff09;&#xff0c;每个函数当然也对应着不同的原理&#x…

Linux操纵零碎下即时通讯软件

作者: openbian 出自: http://www.linuxdiyf.com Linux下的即时通讯软件有多种&#xff0c;我较常用的有skype、QQ、MSN&#xff0c;skype是原生地支撑linux&#xff0c;它对文件传输的支撑最好。目前最新版本可在红旗义务站3中正常运用&#xff0c;但请下载static版本的skype…

赶不上恶性循环

很多事情&#xff0c;会导致恶性循环。我意识到了&#xff0c;也说了&#xff0c;但是我说了不算。我也很无奈。 恶性循环来的时候&#xff0c;只能见步行步了。很多事情&#xff0c;开始时才是最关键的。已经开始了&#xff0c;也迟了。 迟了的时候&#xff0c;再想赶上这个恶…

Java线程:创建与启动

一、定义线程1、扩展java.lang.Thread类。此类中有个run()方法&#xff0c;应该注意其用法&#xff1a;public void run() 如果该线程是使用独立的 Runnable 运行对象构造的&#xff0c;则调用该 Runnable 对象的 run 方法&#xff1b;否则&#xff0c;该方法不执行任何操作并返…

开发杂论

1.json工具之间的比较 2.任务调度 3.消息队列说明 4.ASCII 5.redis锁&#xff08; 标题&#xff09; 6.并发问题 秒杀的场景&#xff0c;可以进行多级淘汰。 1 、秒杀之前几天&#xff0c;先把“预约”的账号洗一遍&#xff0c;留下预售数量 200%左右的账号&#xff0c;其他账…

目标检测光流法(三):opencv下光流Farneback法

上节说到过的calcOpticalFlowPyrLK光流算法&#xff0c;可以看到它实际上是一种稀疏特征点的光流算法&#xff0c;也就是说我们先找到那些&#xff08;特征&#xff09;点需要进行处理&#xff0c;然后再处理&#xff0c;该节介绍下一个全局性的密集光流算法&#xff0c;也就是…

jsDemo

1.在一个层中加入一个元素&#xff08;table&#xff09;://显示休息原因 reasonContent"<table><tr><td>司法</td></tr></table>"; document.getElementById("restReason").innerHTMLreasonContent; //将休…