The Tomcat 4 Servlet/JSP Container下怎样装载类

原创 2003年05月26日 11:36:00

以下的规则覆盖了大约95%的内容,关于开发者和配置者必须要做的工作,关于在什么地方放置类文件和资源文件来使他们变得有效。

对于那些特定某个web应用的类和资源文件,没有打包的类和资源文件放置在你的web应用路径的/WEB-INF/classe下,或者放置包含那些类和资源文件的JAR文件在/WEB-INF/lib

对于那些为所有的WEB应用所共享的WEB应用类和资源文件,没有打包的类和资源文件放置在$CATALINA_HOME/shared/classes下,或者放置那些包含类和资源文件JAR包在$CATALINA_HOME/shared/lib的下面。

序言

就像一些服务应用一样,tomcat4安装一个多样性的class loaders(就是执行java.lang.ClassLoader)类来允许容器的不同部分和网站应用运行在这个容器中,允许存取不同的类和资源的仓库。

Java 2 (that is, JDK 1.2 or later)环境中,class loaders被安排在一个父子树中。当一个class loader被要求装载一个类和资源的时候,他首先指定这个需求到一个父类中,然后寻找自己的需求在这个父类中,如果找不到再接着向下寻找。对于WEB应用的class loader也许或有细微的差别,但是主要的机制都是一样的。

When Tomcat 4 is started, it creates a set of class loaders that are organized into the following parent-child relationships, where the parent class loader is above the child class loader:

TOMCAT4启动的时候,他创建了一套以下父子关系的class loader,并且父类在子类的上面。

  

       Bootstrap

          |

       System

          |

       Common

      /      /

 Catalina   Shared

             /   /

        Webapp1  Webapp2 ...

 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

 

这些class loaders的每一个特征(包括类和资源的源文件)在以下的章节中说明。

Class Loader 定义

就像以上的图表所显示的一样,TOMCAT4在初始化的时候创建以下的class loader

Bootstrap –这个class loader包含了JAVA虚拟机提供的基本运行时的环境类,还有任何当前系统扩展路径($JAVA_HOME/jre/lib/ext)下的JAR文件。注意-一些JAVA虚拟机也许需要多个class loader,或者也许不可见。

System –这个class loader通常从CLASSPATH环境变量的内容中初始化。所有这些类对于TOMCAT内部类和WEB应用都是可见的。但是TOMCAT4标准开始脚本($CATALINA_HOME/bin/catalina.sh 或者 %CATALINA_HOME%/bin/catalina.bat)完全忽略了他自己的CLASSPATH环境变量的内容,取而代之的是从以下的仓库中建立系统class loader

$CATALINA_HOME/bin/bootstrap.jar -包含了初始化TOMCAT4服务的主要方法,和他所依赖的class loader执行类。

$JAVA_HOME/lib/tools.jar -包含了JAVAC编译器,用于把JSP编译成SEVLET

 

Common -这个class loader包含了对于TOMCAT4和所有的WEN应用都可见的额外的类。通常,应用类不应该放置到这里。通过这类的装载,所有在$CATALINA_HOME/common/classes下的未打包的类和资源文件和在$CATALINA_HOME/commons/endorsed $CATALINA_HOME/common/lib directories下的打包的JAR文件都可以变得可见。在缺省的情况下主要包含了以下的包:

jndi.jar - JAVA命名和路径接口API类(只装载在JDK1.2系统中,因为在以后的JDK1.3版本中会被自动包含)。

naming-common.jar -TOMCAT4使用来说明存储器命名关联的JNDI实现

naming-resources.jar - 用来描述一个WEB应用的静态在院的专门的JNDI命名关联实现

servlet.jar - Servlet JSP API

xerces.jar -在缺省的情况下对于TOMCAT内部类和WEB应用可见的XML解析器。对于一个特殊的应用,我们可以在/WEB-INF/lib下包含我们自己的解析器来忽略这个解析器

Catalina -用来实现TOMCAT4初始化的时候包含他自己所有需要的类和资源。这些类和资源对于整个WEB应用是不可见的。所有的未打包的类和资源在$CATALINA_HOME/server/classes下,打包的JAR文件在$CATALINA_HOME/server/lib

 

因此,从这个WEB应用的观点可以看出,类或者资源装载在以下的仓库中,就是以下的顺序:

/WEB-INF/classes 你的WEB应用

/WEB-INF/lib/*.jar 你的WEB应用

你的JVM Bootstrap

系统class loader类(以上说明的)

$CATALINA_HOME/common/classes

$CATALINA_HOME/common/endorsed/*.jar

$CATALINA_HOME/common/lib/*.jar

$CATALINA_HOME/shared/classes

$CATALINA_HOME/shared/lib/*.jar

 

J2SE类和扩展

除了先前的规则,Web应用class loader将拒绝从JAVA语言核心包中装载("java.*" packages).

XML 解析器 JDK 1.4

就象一些其它的改变,JDK1.4发布了JAXP APIS包和Xerces的一个版本。这会影响那些希望使用他们自己的XML解析器。

在先前的TOMCAT4的版本,你可以简单的在$CATALINA_HOME/common/lib下覆盖XML解析器来改变所有的WEB应用的解析器。但是,当我们运行在JDK1.4的时候这个技巧不是很有效的,因为通常class loader委托过程总是选择JDK内部的实现。

JDK1.4通过调用"Endorsed Standards Override Mechanism" 来支持创建JCP(i.e. DOM and SAX from W3C)外部的机制。他也别用来更新XML解析实现。

TOMCAT在命令行开始一个容器的时候,通过包含系统恰当的设置-Djava.endorsed.dirs=$CATALINA_HOME/common/endorsed来调用系统的正确设置。因此,你可以取代安装在这个路径下的解析器,他甚至在JDK1.4种也会得到应用。

Running The Apache Tomcat 8.0 Servlet/JSP Container

================================================================================ Licensed to the A...
  • shile
  • shile
  • 2016年12月21日 22:27
  • 545

Tomcat下的jsp、servlet和javabean的配置实例

经常看到jsp的初学者问tomcat下如何配置jsp、servlet和bean的问题,于是总结了一下如何tomcat下配置jsp、servlet和ben,希望对那些初学者有所帮助。    第一步:下载...
  • Jcoop
  • Jcoop
  • 2007年06月22日 10:06
  • 925

Servlet Servlet的装载三种情况

Servlet的装载三种情况: 1、自动装载:某些Servlet如果需要在Servlet容器启动时就加载,需要在web.xml下它的标签里中,添加优先级代码: 1 数字越小表示该servlet的优...
  • sinat_32873711
  • sinat_32873711
  • 2016年11月15日 13:31
  • 380

Servlet/JSP各规范与Web服务器Tomcat各版本的对应关系

在项目部署的时候,如果对于Web应用没有选择正确的Web服务器版本,应用可能不能正常运行。下图为官方给的Servlet/JSP各规范与Web服务器Tomcat各版本的对应关系,如:支持Servlet ...
  • aspnet2002web
  • aspnet2002web
  • 2016年05月04日 23:43
  • 2057

HttpServlet及Servlet Container原理总结

Servlet顾名思义,服务器端应用程序,HttpServlet是用来处理基于Http的请求的服务器端程序,现在大部分请求都是基于Http的; HttpServlet是一个继承自Servlet的抽象...
  • linfujian1999
  • linfujian1999
  • 2017年02月27日 16:28
  • 275

Tomcat详解(3)---Container 分析

3 ContainerBase 的结构 3.1 ContainerBase 的结构   Container 是Tomcat 中容器的接口,通常使用的Serviet 就封装在其子接口Wrapper ...
  • gchd19921992
  • gchd19921992
  • 2018年01月16日 16:11
  • 33

tomcat 启动报找不到 ActionServlet 错误 解决方法

   看到网上这种错误比较普遍,我也遇到过,情况可能是这样的,我用的是MYeclipse8.5,当自动建一个struts 时,它并没有把 struts所用到的jar文件复制到我外部的tomcat文件的...
  • mxfhhh
  • mxfhhh
  • 2011年03月10日 15:16
  • 583

四、用servlet类返回WEB-INF中的页面

对于外部访问来说,WEB-INF下的文件都是不可见的,即不能通过url获得WEB-INF下的任何文件。 那如何访问WEB-INF下的文件页面呢? 1.web.xml中主页设置成该页面,如/WEB-IN...
  • qq_36326947
  • qq_36326947
  • 2017年04月23日 18:34
  • 1724

Tomcat根据JSP生成Servlet机制深度剖析及核心源代码详解

1、jsp全称java server pag。。java服务器端的页面 2、在传统的网页html文件(*htm,*html)里面加入了java程序片段和jsp标签,就构成了jsp。 3、java片...
  • sunshine940326
  • sunshine940326
  • 2015年07月02日 14:13
  • 769

设置tomcat将jsp编译后的servlet文件的放置目录

Context path="/test" docBase="test/WebRoot" workDir="E:/java/temp" debug="2" privileged="true">/Cont...
  • flynetcn
  • flynetcn
  • 2008年03月14日 16:41
  • 2216
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:The Tomcat 4 Servlet/JSP Container下怎样装载类
举报原因:
原因补充:

(最多只允许输入30个字)