JSP中tomcat的SQL Server2000数据库连接池的配置
创始人
2024-04-08 12:31:10
0

JSP中tomcat的SQL Server2000数据库连接池的配置环境:
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) --环境入口,设置应用程序如何操作。
2) --资源参数,一般是数据库驱动程序、JavaMail Session、自定义类工厂等。
3) --在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) --设置域个可变的JNDI InitialContext入口的名字和值(同上面说的等价)。
2) --设置应用程序可用的资源的名字和类型(同上面说的等价)。
3) --设置Java资源类工厂的名称或将用的JavaBean属性。
4) --给全局JNDI环境(JNDI Context)添加一个链接。
上述这些标志符必须放在之间(针对专门的网页应用程序)或之间。
此外,设在网页应用环境描述(Web Application Descriptor)(/WEB-INF/web.xml)里的名字和值也在初始环境(Initial Context)里被设置,当被元素值允许时将被重设初始值。
全局变量能在子元素的里设置。

数据库连接池概述:

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

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

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

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

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

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

配置Tomcat数据库连接池的前提:
1. 必须装有Java运行环境;
2. 必须有SQL Server2000数据库服务器(可以不在本地);
3. 必须有jtds.jar,并将它放在$CATALINA_HOME/common/lib目录下(只能是这里)。使用它是因为Microsoft公司的Java SQL Server驱动程序不支持二次查询,可到网上搜到。目前使用的是jtds-0.6.jar。

在$CATALINA_HOME/conf/server.xml里设置数据库连接池:
下面是配置的代码,必须放在之间。

  1.  path="/quality" docBase="quality" debug="0" reloadable
    ="true" crossContext="true"> 
  2.  className="org.apache.catalina.logger.FileLogger" prefix
    ="localhost_quality_log." suffix=".txt" timestamp="true"/> 
  3.  name="jdbc/connectDB" auth="Container" 
    type="javax.sql.DataSource"/> 
  4.  name="jdbc/connectDB"> 
  5.  
  6.   maxActivename> 
  7.    
  8.   100value> 
  9. parameter> 
  10.  
  11.   maxIdlename> 
  12.    
  13.   30value> 
  14. parameter> 
  15.  
  16.   maxWaitname> 
  17.    
  18.   10000value> 
  19. parameter> 
  20.  
  21.   removeAbandonedname> 
  22.    
  23.   truevalue> 
  24. parameter> 
  25.  
  26.   removeAbandonedTimeoutname> 
  27.  
  28.   60value> 
  29. parameter> 
  30.  
  31.   logAbandonedname> 
  32.    
  33.   falsevalue> 
  34. parameter> 
  35.  
  36.   factoryname> 
  37.   > 
  38.   org.apache.commons.dbcp.BasicDataSourceFactoryvalue> 
  39. parameter> 
  40.  
  41.   usernamename> 
  42.    
  43.   Iorishiniervalue> 
  44. parameter> 
  45.  
  46.   passwordname> 
  47.    
  48.   mypasswdvalue> 
  49. parameter> 
  50.  
  51.   driverClassNamename> 
  52.    
  53.   net.sourceforge.jtds.jdbc.Drivervalue> 
  54. parameter> 
  55.  
  56.   urlname> 
  57.    
  58.   jdbc:jtds:sqlserver://127.127.127.127:1433/Northwindvalue> 
  59. parameter> 
  60. ResourceParams> 
  61. Context> 

下面是一些参数的说明:

  1.  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里设置被引用的资源:
下面是配置代码,必须放在里。

  1.  
  2.  
  3. connectDB testdescription> 
  4. jdbc/connectDBres-ref-name> 
  5. javax.sql.DataSourceres-type> 
  6. Containerres-auth> 
  7. resource-ref> 
  8.  

下面是一下参数的必要说明:
1) description  对被引用的资源的描述。
2) res-ref-name  资源名称。见上面的
3) res-type  资源类型。见上面的

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

  1. <%@ page contentType="text/html;charset=GBK"%> 
  2. <%@ page errorPage="error.jsp"%> 
  3. <%@ page import="javax.naming.*"%> 
  4. <%@ page import="javax.sql.*"%> 
  5. <%@ page import="java.sql.*"%> 
  6.  
  7.  
  8. head> 
  9.  
  10.   <

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

【编辑推荐】

  1. JSP自定义标签由浅到深详细讲解
  2. 在JSP环境中配置使用fckeditor详细讲解
  3. 基于JSP实现数据库中图片的存储与显示
  4. 构造JSP和Javabean开发和发布环境的方法
  5. JSP+JavaBean+Servlet工作原理实例讲解

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...