分享
 
 
 

JSP中tomcat的SQL Server2000数据库连接池的配置

王朝厨房·作者佚名  2007-01-04
窄屏简体版  字體: |||超大  

环境:

1. 数据库:Microsoft SQL Server 2000

2. 数据库驱动程序:net.sourceforge.jtds.jdbc.Driver

JNDI(Java Naming and Directory Interface)概述:

Tomcat4(5)提供了一个与Java Enterprise Edition应用服务相兼容的JNDI--InitialContext实现实例。它的初始数据设置在$CATALINA_HOME/conf/server.xml文件里,并可能在网页应用环境描述(/WEB-INF/web.xml)里被下列元素引用:

1) <env-entry>--环境入口,设置应用程序如何操作。

2) <resource-ref>--资源参数,一般是数据库驱动程序、JavaMail Session、自定义类工厂等。

3) <resource-env-ref>--在Servlet 2.4里用来简化设置不需认证信息的资源资源如环境参数、resource-ref变量。

InitialContext在网页应用程序初始化时被设置,用来支持网页应用程序组件。所有的入口和资源都放在JNDI命名空间里的java:comp/env段里。点击下列网址以获取更多信息:

1) Java命名和目录接口(Java Naming and Directory Interface)

2) J2EE平台说明(J2EE Platform Specification)

设置JNDI资源

设置JNDI资源要在$CATALINA_HOME/conf/server.xml文件里使用下列标志符:

1) <Environment>--设置域个可变的JNDI InitialContext入口的名字和值(同上面说的<env-entry>等价)。

2) <Resource>--设置应用程序可用的资源的名字和类型(同上面说的<resource-ref>等价)。

3) <ResourceParams>--设置Java资源类工厂的名称或将用的JavaBean属性。

4) <ResourceLink>--给全局JNDI环境(JNDI Context)添加一个链接。

上述这些标志符必须放在<Context>和</Context>之间(针对专门的网页应用程序)或<DefaultContext>和</DefaultContext>之间。

此外,设在网页应用环境描述(Web Application Descriptor)(/WEB-INF/web.xml)里的名字和值也在初始环境(Initial Context)里被设置,当被<Environemt>元素值允许时将被重设初始值。

全局变量能在<Server>子元素的<GlobalNamingResources>里设置。

数据库连接池概述:

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

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

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

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

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

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

配置Tomcat数据库连接池的前提:

1. 必须装有Java运行环境;

2. 必须有SQL Server2000数据库服务器(可以不在本地);

3. 必须有jtds.jar,并将它放在$CATALINA_HOME/common/lib目录下(只能是这里)。使用它是因为Microsoft公司的Java SQL Server驱动程序不支持二次查询,可到网上搜到。目前使用的是jtds-1.1.jar。

在$CATALINA_HOME/conf/server.xml里设置数据库连接池:

下面是配置的代码,必须放在<Host>和</Host>之间。

<Context path="/quality" docBase="quality" debug="0" reloadable="true" crossContext="true">

<Logger className="org.apache.catalina.logger.FileLogger" prefix="localhost_quality_log." suffix=".txt" timestamp="true"/>

<Resource name="jdbc/connectDB" auth="Container" type="javax.sql.DataSource"/>

<ResourceParams name="jdbc/connectDB">

<parameter>

<name>maxActive</name>

<!-- Maximum number of DB connections in pool.Set to 0 for no limit. -->

<value>100</value>

</parameter>

<parameter>

<name>maxIdle</name>

<!-- Maximum number of idle DB connections to retain in pool.Set to 0 for no limit. -->

<value>30</value>

</parameter>

<parameter>

<name>maxWait</name>

<!-- Maximum time to wait for a DB connection to become available in ms.An exception is thrown if this timeout is exceeded.Set to -1 to wait indefinitely. -->

<value>10000</value>

</parameter>

<parameter>

<name>removeAbandoned</name>

<!-- Abandoned DB connections are removed and recycled -->

<value>true</value>

</parameter>

<parameter>

<name>removeAbandonedTimeout</name>

<!-- Use the removeAbandonedTimeout parameter to set the number of seconds a DB connection has been idle before it is considered abandoned. -->

<value>60</value>

</parameter>

<parameter>

<name>logAbandoned</name>

<!-- Log a stack trace of the code which abandoned -->

<value>false</value>

</parameter>

<parameter>

<name>factory</name>

<!-DBCP Basic Datasource Factory -->

<value>org.apache.commons.dbcp.BasicDataSourceFactory</value>

</parameter>

<parameter>

<name>username</name>

<!-- Database User Name -->

<value>Iorishinier</value>

</parameter>

<parameter>

<name>password</name>

<!-- User Password -->

<value>mypasswd</value>

</parameter>

<parameter>

<name>driverClassName</name>

<!-- Database Driver Class Name -->

<value>net.sourceforge.jtds.jdbc.Driver</value>

</parameter>

<parameter>

<name>url</name>

<!-- Database Address -->

<value>jdbc:jtds:sqlserver://127.127.127.127:1433/Northwind</value>

</parameter>

</ResourceParams>

</Context>

下面是一些参数的说明:

<Context path="/quality" docBase="quality" debug="0" reloadable="true" crossContext="true">

其中:

1) path 指定路径,这里设定的是$CATALINA_HOME/webapps下的quality目录;

2) docBase 文件根目录。

3) reloader 当网页被更新时是否重新编译。

4) maxActive 连接池的最大数据库连接数。设为0表示无限制。

5) maxIdle 数据库连接的最大空闲时间。超过此空闲时间,数据库连接将被标记为不可用,然后被释放。设为0表示无限制。

6) maxWait 最大建立连接等待时间。如果超过此时间将接到异常。设为-1表示无限制。

7) removeAbandoned 回收被遗弃的(一般是忘了释放的)数据库连接到连接池中。

8) removeAbandonedTimeout 数据库连接过多长时间不用将被视为被遗弃而收回连接池中。

9) logAbandoned 将被遗弃的数据库连接的回收记入日志。

10) driverClassName JDBC驱动程序。

11) url 数据库连接字符串

在$CATALINA_HOME/webapps/quality/WEB-INF/web.xml里设置被引用的资源:

下面是配置代码,必须放在<web-app>和</web-app>里。

<!-- Database Config start -->

<resource-ref>

<description>connectDB test</description>

<res-ref-name>jdbc/connectDB</res-ref-name>

<res-type>javax.sql.DataSource</res-type>

<res-auth>Container</res-auth>

</resource-ref>

<!-- Database Config end -->

下面是一下参数的必要说明:

1) description 对被引用的资源的描述。

2) res-ref-name 资源名称。见上面的<ResourceParams name="jdbc/connectDB">

3) res-type 资源类型。见上面的<Resource name="jdbc/connectDB" auth="Container" type="javax.sql.DataSource"/>

在JSP中使用资源:

这是在$CATALINA_HOME/webapps/quality下的某级子目录里的jsp网页文件部分代码:

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

<%@ page errorPage="error.jsp"%>

<%@ page import="javax.naming.*"%>

<%@ page import="javax.sql.*"%>

<%@ page import="java.sql.*"%>

<html>

<head>

</head>

<body>

<%

………………

………………

// 数据库操作

Context ctx=null;

Connection cnn=null;

Statement stmt=null;

ResultSet rs=null;

try

{

ctx=new InitialContext();

if(ctx==null)

throw new Exception("没有匹配的环境");

DataSource ds=(DataSource)ctx.lookup("java:comp/env/jdbc/connectDB");

if(ds==null)

throw new Exception("没有匹配数据库");

cnn=ds.getConnection();

stmt=cnn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);

rs=stmt.executeQuery("select * from table1");

………………

………………

}

finally

{

if(rs!=null)

rs.close();

if(stmt!=null)

stmt.close();

if(cnn!=null)

cnn.close();

if(ctx!=null)

ctx.close();

}

%>

</body>

</html>

代码说明:

DataSource ds=(DataSource)ctx.lookup("java:comp/env/jdbc/connectDB");

上面这句应用了刚才设的资源。

资源使用完要释放,尤其是Context资源,见try-catch-finally部分的finally代码段,这是一种好的习惯。资源释放时如果释放了上级资源,下级资源将先被释放。如:释放了ctx,那么资源释放顺序将是rs,stmt,cnn,ctx。换句话说,如果释放了ctx,那么rs,stmt和cnn都将不可用了。

这里的释放资源只是将数据库连接返回连接池中,并不是把资源真正释放掉,见数据库连接池概述。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有