最新更新 sitemap 网站制作设计本站搜索
网页设计
国外网站 韩国网站 个人主页 手提袋设计 CSS 网页特效 平面设计 网站设计 Flash CMS技巧 服装网站 php教程 photoshop 画册 服务器选用 数据库 Office
虚拟主机 域名注册 云主机 网页设计 客服QQ:8208442
当前位置:首页 > 编程开发 > jsp教程

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

日期:11-19    来源:中国设计秀    作者:cnwebshow.com

jsp中tomcat的SQL Server2000数据库连接池的配置nc9中国设计秀
环境:nc9中国设计秀
1. 数据库:Microsoft SQL Server 2000nc9中国设计秀
2. 数据库驱动程序:net.sourceforge.jtds.jdbc.Drivernc9中国设计秀
JNDI(java Naming and Directory Interface)概述:nc9中国设计秀
Tomcat4(5)提供了一个与Java EnterPRise Edition应用服务相兼容的JNDI--InitialContext实现实例。它的初始数据设置在$CATALINA_HOME/conf/server.xml文件里,并可能在网页应用环境描述(/WEB-INF/web.xml)里被下列元素引用:nc9中国设计秀
1) <env-entry>--环境入口,设置应用程序如何操作。nc9中国设计秀
2) <resource-ref>--资源参数,一般是数据库驱动程序、JavaMail session、自定义类工厂等。nc9中国设计秀
3) <resource-env-ref>--在Servlet 2.4里用来简化设置不需认证信息的资源资源如环境参数、resource-ref变量。nc9中国设计秀
InitialContext在网页应用程序初始化时被设置,用来支持网页应用程序组件。所有的入口和资源都放在JNDI命名空间里的java:comp/env段里。点击下列网址以获取更多信息:nc9中国设计秀
1) Java命名和目录接口(Java Naming and Directory Interface)nc9中国设计秀
2) J2EE平台说明(J2EE Platform Specification)nc9中国设计秀
设置JNDI资源nc9中国设计秀
设置JNDI资源要在$CATALINA_HOME/conf/server.xml文件里使用下列标志符:nc9中国设计秀
1) <Environment>--设置域个可变的JNDI InitialContext入口的名字和值(同上面说的<env-entry>等价)。nc9中国设计秀
2) <Resource>--设置应用程序可用的资源的名字和类型(同上面说的<resource-ref>等价)。nc9中国设计秀
3) <ResourceParams>--设置Java资源类工厂的名称或将用的JavaBean属性。nc9中国设计秀
4) <ResourceLink>--给全局JNDI环境(JNDI Context)添加一个链接。nc9中国设计秀
上述这些标志符必须放在<Context>和</Context>之间(针对专门的网页应用程序)或<DefaultContext>和</DefaultContext>之间。nc9中国设计秀
此外,设在网页应用环境描述(Web application Descriptor)(/WEB-INF/web.xml)里的名字和值也在初始环境(Initial Context)里被设置,当被<Environemt>元素值允许时将被重设初始值。nc9中国设计秀
全局变量能在<Server>子元素的<GlobalNamingResources>里设置。nc9中国设计秀
数据库连接池概述:nc9中国设计秀
数据库连接是一种关键的有限的昂贵的资源,这一点在多用户的网页应用程序中体现得尤为突出。对数据库连接的管理能显著影响到整个应用程序的伸缩性和健壮性,影响到程序的性能指标。数据库连接池正是针对这个问题提出来的。nc9中国设计秀
数据库连接池负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而再不是重新建立一个;释放空闲时间超过最大空闲时间的数据库连接来避免因为没有释放数据库连接而引起的数据库连接遗漏。这项技术能明显提高对数据库操作的性能。nc9中国设计秀
数据库连接池在初始化时将创建一定数量的数据库连接放到连接池中,这些数据库连接的数量是由最小数据库连接数来设定的。无论这些数据库连接是否被使用,连接池都将一直保证至少拥有这么多的连接数量。连接池的最大数据库连接数量限定了这个连接池能占有的最大连接数,当应用程序向连接池请求的连接数超过最大连接数量时,这些请求将被加入到等待队列中。数据库连接池的最小连接数和最大连接数的设置要考虑到下列几个因素:nc9中国设计秀
1) 最小连接数是连接池一直保持的数据库连接,所以如果应用程序对数据库连接的使用量不大,将会有大量的数据库连接资源被浪费;nc9中国设计秀
2) 最大连接数是连接池能申请的最大连接数,如果数据库连接请求超过此数,后面的数据库连接请求将被加入到等待队列中,这会影响之后的数据库操作。nc9中国设计秀
3) 如果最小连接数与最大连接数相差太大,那么最先的连接请求将会获利,之后超过最小连接数量的连接请求等价于建立一个新的数据库连接。不过,这些大于最小连接数的数据库连接在使用完不会马上被释放,它将被放到连接池中等待重复使用或是空闲超时后被释放。nc9中国设计秀
配置Tomcat数据库连接池的前提:nc9中国设计秀
1. 必须装有Java运行环境;nc9中国设计秀
2. 必须有SQL Server2000数据库服务器(可以不在本地);nc9中国设计秀
3. 必须有jtds.jar,并将它放在$CATALINA_HOME/common/lib目录下(只能是这里)。使用它是因为Microsoft公司的Java SQL Server驱动程序不支持二次查询,可到网上搜到。目前使用的是jtds-0.6.jar。nc9中国设计秀
在$CATALINA_HOME/conf/server.xml里设置数据库连接池:nc9中国设计秀
下面是配置的代码,必须放在<Host>和</Host>之间。nc9中国设计秀
<Context path="/quality" docBase="quality" debug="0" reloadable="true" crossContext="true">nc9中国设计秀
<Logger className="org.apache.catalina.logger.FileLogger" prefix="localhost_quality_log." suffix=".txt" timestamp="true"/>nc9中国设计秀
<Resource name="jdbc/connectDB" auth="Container" type="javax.sql.DataSource"/>nc9中国设计秀
<ResourceParams name="jdbc/connectDB">nc9中国设计秀
 <parameter>nc9中国设计秀
  <name>maxActive</name>nc9中国设计秀
  <!-- Maximum number of DB connections in pool.Set to 0 for no limit. -->nc9中国设计秀
  <value>100</value>nc9中国设计秀
 </parameter>nc9中国设计秀
 <parameter>nc9中国设计秀
  <name>maxIdle</name>nc9中国设计秀
  <!-- Maximum number of idle DB connections to retain in pool.Set to 0 for no limit. -->nc9中国设计秀
  <value>30</value>nc9中国设计秀
 </parameter>nc9中国设计秀
 <parameter>nc9中国设计秀
  <name>maxWait</name>nc9中国设计秀
  <!-- 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. -->nc9中国设计秀
  <value>10000</value>nc9中国设计秀
 </parameter>nc9中国设计秀
 <parameter>nc9中国设计秀
  <name>removeAbandoned</name>nc9中国设计秀
  <!-- Abandoned DB connections are removed and recycled -->nc9中国设计秀
  <value>true</value>nc9中国设计秀
 </parameter>nc9中国设计秀
 <parameter>nc9中国设计秀
  <name>removeAbandonedTimeout</name>nc9中国设计秀
  <!-- Use the removeAbandonedTimeout parameter to set the number of seconds a DB connection has been idle before it is considered abandoned.  -->nc9中国设计秀
  <value>60</value>nc9中国设计秀
 </parameter>nc9中国设计秀
 <parameter>nc9中国设计秀
  <name>logAbandoned</name>nc9中国设计秀
  <!-- Log a stack trace of the code which abandoned -->nc9中国设计秀
  <value>false</value>nc9中国设计秀
 </parameter>nc9中国设计秀
 <parameter>nc9中国设计秀
  <name>factory</name>nc9中国设计秀
  <!-DBCP Basic Datasource Factory -->nc9中国设计秀
  <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>nc9中国设计秀
 </parameter>nc9中国设计秀
 <parameter>nc9中国设计秀
  <name>username</name>nc9中国设计秀
  <!-- Database User Name -->nc9中国设计秀
  <value>Iorishinier</value>nc9中国设计秀
 </parameter>nc9中国设计秀
 <parameter>nc9中国设计秀
  <name>password</name>nc9中国设计秀
  <!-- User Password -->nc9中国设计秀
  <value>mypasswd</value>nc9中国设计秀
 </parameter>nc9中国设计秀
 <parameter>nc9中国设计秀
  <name>driverClassName</name>nc9中国设计秀
  <!-- Database Driver Class Name -->nc9中国设计秀
  <value>net.sourceforge.jtds.jdbc.Driver</value>nc9中国设计秀
 </parameter>nc9中国设计秀
 <parameter>nc9中国设计秀
  <name>url</name>nc9中国设计秀
  <!-- Database Address -->nc9中国设计秀
  <value>jdbc:jtds:sqlserver://127.127.127.127:1433/Northwind</value>

本文引用地址:/bc/article_46734.html
网站地图 | 关于我们 | 联系我们 | 网站建设 | 广告服务 | 版权声明 | 免责声明