tomcat 工作原理

article/2025/9/14 1:23:59

大致的架构是 jsp+tomcat+mysql,记录tomcat学习一点笔记。

Tomcat是Servlet运行环境(容器),每个servlet执行init(),service(),destory()

以下是servlet的作用

Servlet的调用

Tomcat的工作模式3种:独立Servlet,进程内servlet,进程外servlet。

Tomcat是一个基于组件的服务器,他的构建组件都是可以配置的,其中最外层的组件是Catalina Servlet容器,其他组阿金一定要按照一定的格式要求配置在这个顶层的容器中。

  Tomcat各个组件是在$CATLINA_HOME/conf/server.xml文件中配置的。

 

复制代码
< Server >  顶层类元素,可包含多个service
< Service >  顶层类元素,可包含一个Engine和多个Connector
< Connector />  链接类容器,代表通信接口
< Engine >  容器元素,为Service处理客户请求,含多个Host
< Host >  容器元素,为Host处理客户请求,含多个Context
< Context />  容器元素,为Web应用处理客户请求
</ Host >
</ Engine >
</ Service >
</ Server >
复制代码

 

一个java web应用在Tomcat中与一个Context对应,是一一对应关系。

Java Web应该可以包含如下内容:

  • Servlet
  • JSP pages
  • Java Classes
  • static resources(HTML documents, pictures, etc.)
  • Description Documents of Web  Applications.


1 - Tomcat Server的组成部分

1.1 - Server

A Server element represents the entire Catalina servlet container. (Singleton)

1.2 - Service

A Service element represents the combination of one or more Connector components that share a single Engine
Service是这样一个集合:它由一个或者多个Connector组成,以及一个Engine,负责处理所有Connector所获得的客户请求

1.3 - Connector

一个Connector将在某个指定端口上侦听客户请求,并将获得的请求交给Engine来处理,从Engine处获得回应并返回客户
TOMCAT有两个典型的Connector,一个直接侦听来自browser的http请求,一个侦听来自其它WebServer的请求
Coyote Http/1.1 Connector 在端口8080处侦听来自客户browser的http请求
Coyote JK2 Connector 在端口8009处侦听来自其它WebServer(Apache)的servlet/jsp代理请求

1.4 - Engine

The Engine element represents the entire request processing machinery associated with a particular Service
It receives and processes all requests from one or more Connectors
and returns the completed response to the Connector for ultimate transmission back to the client
Engine下可以配置多个虚拟主机Virtual Host,每个虚拟主机都有一个域名
当Engine获得一个请求时,它把该请求匹配到某个Host上,然后把该请求交给该Host来处理
Engine有一个默认虚拟主机,当请求无法匹配到任何一个Host上的时候,将交给该默认Host来处理

1.5 - Host

代表一个Virtual Host,虚拟主机,每个虚拟主机和某个网络域名Domain Name相匹配
每个虚拟主机下都可以部署(deploy)一个或者多个Web App,每个Web App对应于一个Context,有一个Context path
当Host获得一个请求时,将把该请求匹配到某个Context上,然后把该请求交给该Context来处理
匹配的方法是“最长匹配”,所以一个path==""的Context将成为该Host的默认Context
所有无法和其它Context的路径名匹配的请求都将最终和该默认Context匹配

1.6 - Context

一个Context对应于一个Web Application,一个Web Application由一个或者多个Servlet组成
Context在创建的时候将根据配置文件$CATALINA_HOME/conf/web.xml和$WEBAPP_HOME/WEB-INF/web.xml载入Servlet类
当Context获得请求时,将在自己的映射表(mapping table)中寻找相匹配的Servlet类
如果找到,则执行该类,获得请求的回应,并返回

2 - Tomcat Server的结构图

3 - 配置文件$CATALINA_HOME/conf/server.xml的说明

该文件描述了如何启动Tomcat Server

[html]  view plain copy
  1. <!----------------------------------------------------------------------------------------------->  
  2.   
  3.   
  4.   
  5. <!-- 启动Server  
  6.      在端口8005处等待关闭命令  
  7.      如果接受到"SHUTDOWN"字符串则关闭服务器  
  8.      -->  
  9.   
  10. <Server port="8005" shutdown="SHUTDOWN" debug="0">  
  11.   
  12.   
  13.   <!-- Listener ???  
  14.        目前没有看到这里  
  15.        -->  
  16.   
  17.   <Listener className="org.apache.catalina.mbeans.ServerLifecycleListener" debug="0"/>  
  18.   <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" debug="0"/>  
  19.   
  20.   
  21.   <!-- Global JNDI resources ???  
  22.        目前没有看到这里,先略去  
  23.        -->  
  24.   
  25.   <GlobalNamingResources>  
  26.     ... ... ... ...  
  27.   </GlobalNamingResources>  
  28.   
  29.   
  30.   <!-- Tomcat的Standalone Service  
  31.        Service是一组Connector的集合  
  32.        它们共用一个Engine来处理所有Connector收到的请求  
  33.        -->  
  34.   
  35.   <Service name="Tomcat-Standalone">  
  36.   
  37.   
  38.     <!-- Coyote HTTP/1.1 Connector  
  39.          className : 该Connector的实现类是org.apache.coyote.tomcat4.CoyoteConnector  
  40.          port : 在端口号8080处侦听来自客户browser的HTTP1.1请求  
  41.          minProcessors : 该Connector先创建5个线程等待客户请求,每个请求由一个线程负责  
  42.          maxProcessors : 当现有的线程不够服务客户请求时,若线程总数不足75个,则创建新线程来处理请求  
  43.          acceptCount : 当现有线程已经达到最大数75时,为客户请求排队  
  44.                        当队列中请求数超过100时,后来的请求返回Connection refused错误  
  45.          redirectport : 当客户请求是https时,把该请求转发到端口8443去  
  46.          其它属性略  
  47.          -->  
  48.   
  49.     <Connector className="org.apache.coyote.tomcat4.CoyoteConnector"   
  50.                port="8080"   
  51.                minProcessors="5" maxProcessors="75" acceptCount="100"   
  52.                enableLookups="true"   
  53.                redirectPort="8443"   
  54.                debug="0"   
  55.                connectionTimeout="20000"   
  56.                useURIValidationHack="false"   
  57.                disableUploadTimeout="true" />  
  58.   
  59.   
  60.     <!-- Engine用来处理Connector收到的Http请求  
  61.          它将匹配请求和自己的虚拟主机,并把请求转交给对应的Host来处理  
  62.          默认虚拟主机是localhost  
  63.          -->  
  64.   
  65.     <Engine name="Standalone" defaultHost="localhost" debug="0">  
  66.       
  67.   
  68.       <!-- 日志类,目前没有看到,略去先 -->  
  69.   
  70.       <Logger className="org.apache.catalina.logger.FileLogger" .../>  
  71.   
  72.       <!-- Realm,目前没有看到,略去先 -->  
  73.   
  74.       <Realm className="org.apache.catalina.realm.UserDatabaseRealm" .../>  
  75.   
  76.   
  77.       <!-- 虚拟主机localhost  
  78.            appBase : 该虚拟主机的根目录是webapps/  
  79.            它将匹配请求和自己的Context的路径,并把请求转交给对应的Context来处理  
  80.            -->  
  81.   
  82.       <Host name="localhost" debug="0" appBase="webapps" unpackWARs="true" autoDeploy="true">  
  83.         
  84.   
  85.         <!-- 日志类,目前没有看到,略去先 -->  
  86.   
  87.         <Logger className="org.apache.catalina.logger.FileLogger" .../>  
  88.         
  89.   
  90.         <!-- Context,对应于一个Web App  
  91.              path : 该Context的路径名是"",故该Context是该Host的默认Context  
  92.              docBase : 该Context的根目录是webapps/mycontext/  
  93.              -->  
  94.   
  95.         <Context path="" docBase="mycontext" debug="0"/>  
  96.           
  97.   
  98.         <!-- 另外一个Context,路径名是/wsota -->  
  99.   
  100.         <Context path="/wsota" docBase="wsotaProject" debug="0"/>  
  101.                
  102.           
  103.       </Host>  
  104.         
  105.     </Engine>  
  106.   
  107.   </Service>  
  108.   
  109. </Server>  
  110.   
  111.   
  112. <!----------------------------------------------------------------------------------------------->  


 

4 - Context的部署配置文件web.xml的说明

一个Context对应于一个Web App,每个Web App是由一个或者多个servlet组成的
当一个Web App被初始化的时候,它将用自己的ClassLoader对象载入“部署配置文件web.xml”中定义的每个servlet类
它首先载入在$CATALINA_HOME/conf/web.xml中部署的servlet类
然后载入在自己的Web App根目录下的WEB-INF/web.xml中部署的servlet类
web.xml文件有两部分:servlet类定义和servlet映射定义
每个被载入的servlet类都有一个名字,且被填入该Context的映射表(mapping table)中,和某种URL PATTERN对应
当该Context获得请求时,将查询mapping table,找到被请求的servlet,并执行以获得请求回应

分析一下所有的Context共享的web.xml文件,在其中定义的servlet被所有的Web App载入

[html]  view plain copy
  1. <!----------------------------------------------------------------------------------------------->  
  2.   
  3.   
  4. <web-app>  
  5.   
  6.   
  7.   <!-- 概述:  
  8.        该文件是所有的WEB APP共用的部署配置文件,  
  9.        每当一个WEB APP被DEPLOY,该文件都将先被处理,然后才是WEB APP自己的/WEB-INF/web.xml  
  10.        -->  
  11.   
  12.   
  13.   
  14.   <!--  +-------------------------+  -->  
  15.   <!--  |    servlet类定义部分    |  -->  
  16.   <!--  +-------------------------+  -->  
  17.   
  18.     
  19.   
  20.   <!-- DefaultServlet  
  21.        当用户的HTTP请求无法匹配任何一个servlet的时候,该servlet被执行  
  22.        URL PATTERN MAPPING : /  
  23.        -->  
  24.   
  25.     <servlet>  
  26.         <servlet-name>default</servlet-name>  
  27.         <servlet-class>  
  28.           org.apache.catalina.servlets.DefaultServlet  
  29.         </servlet-class>  
  30.         <init-param>  
  31.             <param-name>debug</param-name>  
  32.             <param-value>0</param-value>  
  33.         </init-param>  
  34.         <init-param>  
  35.             <param-name>listings</param-name>  
  36.             <param-value>true</param-value>  
  37.         </init-param>  
  38.         <load-on-startup>1</load-on-startup>  
  39.     </servlet>  
  40.   
  41.   
  42.   <!-- InvokerServlet  
  43.        处理一个WEB APP中的匿名servlet  
  44.        当一个servlet被编写并编译放入/WEB-INF/classes/中,却没有在/WEB-INF/web.xml中定义的时候  
  45.        该servlet被调用,把匿名servlet映射成/servlet/ClassName的形式  
  46.        URL PATTERN MAPPING : /servlet/*  
  47.        -->  
  48.   
  49.     <servlet>  
  50.         <servlet-name>invoker</servlet-name>  
  51.         <servlet-class>  
  52.           org.apache.catalina.servlets.InvokerServlet  
  53.         </servlet-class>  
  54.         <init-param>  
  55.             <param-name>debug</param-name>  
  56.             <param-value>0</param-value>  
  57.         </init-param>  
  58.         <load-on-startup>2</load-on-startup>  
  59.     </servlet>  
  60.   
  61.   
  62.   <!-- JspServlet  
  63.        当请求的是一个JSP页面的时候(*.jsp)该servlet被调用  
  64.        它是一个JSP编译器,将请求的JSP页面编译成为servlet再执行  
  65.        URL PATTERN MAPPING : *.jsp  
  66.        -->  
  67.   
  68.     <servlet>  
  69.         <servlet-name>jsp</servlet-name>  
  70.         <servlet-class>org.apache.jasper.servlet.JspServlet</servlet-class>  
  71.         <init-param>  
  72.             <param-name>logVerbosityLevel</param-name>  
  73.             <param-value>WARNING</param-value>  
  74.         </init-param>  
  75.         <load-on-startup>3</load-on-startup>  
  76.     </servlet>  
  77.   
  78.   
  79.   
  80.   <!--  +---------------------------+  -->  
  81.   <!--  |    servlet映射定义部分    |  -->  
  82.   <!--  +---------------------------+  -->  
  83.   
  84.       
  85.     <servlet-mapping>  
  86.         <servlet-name>default</servlet-name>  
  87.         <url-pattern>/</url-pattern>  
  88.     </servlet-mapping>  
  89.   
  90.     <servlet-mapping>  
  91.         <servlet-name>invoker</servlet-name>  
  92.         <url-pattern>/servlet/*</url-pattern>  
  93.     </servlet-mapping>  
  94.   
  95.     <servlet-mapping>  
  96.         <servlet-name>jsp</servlet-name>  
  97.         <url-pattern>*.jsp</url-pattern>  
  98.     </servlet-mapping>  
  99.   
  100.   
  101.   <!--  +------------------------+  -->  
  102.   <!--  |    其它部分,略去先    |  -->  
  103.   <!--  +------------------------+  -->  
  104.   
  105.     ... ... ... ...  
  106.   
  107. </web-app>  
  108.   
  109.   
  110. <!----------------------------------------------------------------------------------------------->  


5 - Tomcat Server处理一个http请求的过程

假设来自客户的请求为:
http://localhost:8080/wsota/wsota_index.jsp

1) 请求被发送到本机端口8080,被在那里侦听的Coyote HTTP/1.1 Connector获得
2) Connector把该请求交给它所在的Service的Engine来处理,并等待来自Engine的回应
3) Engine获得请求localhost/wsota/wsota_index.jsp,匹配它所拥有的所有虚拟主机Host
4) Engine匹配到名为localhost的Host(即使匹配不到也把请求交给该Host处理,因为该Host被定义为该Engine的默认主机)
5) localhost Host获得请求/wsota/wsota_index.jsp,匹配它所拥有的所有Context
6) Host匹配到路径为/wsota的Context(如果匹配不到就把该请求交给路径名为""的Context去处理)
7) path="/wsota"的Context获得请求/wsota_index.jsp,在它的mapping table中寻找对应的servlet
8) Context匹配到URL PATTERN为*.jsp的servlet,对应于JspServlet类
9) 构造HttpServletRequest对象和HttpServletResponse对象,作为参数调用JspServlet的doGet或doPost方法
10)Context把执行完了之后的HttpServletResponse对象返回给Host
11)Host把HttpServletResponse对象返回给Engine
12)Engine把HttpServletResponse对象返回给Connector
13)Connector把HttpServletResponse对象返回给客户browser



1 - Tomcat Server的组成部分

1.1 - Server

A Server element represents the entire Catalina servlet container. (Singleton)

1.2 - Service

A Service element represents the combination of one or more Connector components that share a single Engine
Service是这样一个集合:它由一个或者多个Connector组成,以及一个Engine,负责处理所有Connector所获得的客户请求

1.3 - Connector

一个Connector将在某个指定端口上侦听客户请求,并将获得的请求交给Engine来处理,从Engine处获得回应并返回客户
TOMCAT有两个典型的Connector,一个直接侦听来自browser的http请求,一个侦听来自其它WebServer的请求
Coyote Http/1.1 Connector 在端口8080处侦听来自客户browser的http请求
Coyote JK2 Connector 在端口8009处侦听来自其它WebServer(Apache)的servlet/jsp代理请求

1.4 - Engine

The Engine element represents the entire request processing machinery associated with a particular Service
It receives and processes all requests from one or more Connectors
and returns the completed response to the Connector for ultimate transmission back to the client
Engine下可以配置多个虚拟主机Virtual Host,每个虚拟主机都有一个域名
当Engine获得一个请求时,它把该请求匹配到某个Host上,然后把该请求交给该Host来处理
Engine有一个默认虚拟主机,当请求无法匹配到任何一个Host上的时候,将交给该默认Host来处理

1.5 - Host

代表一个Virtual Host,虚拟主机,每个虚拟主机和某个网络域名Domain Name相匹配
每个虚拟主机下都可以部署(deploy)一个或者多个Web App,每个Web App对应于一个Context,有一个Context path
当Host获得一个请求时,将把该请求匹配到某个Context上,然后把该请求交给该Context来处理
匹配的方法是“最长匹配”,所以一个path==""的Context将成为该Host的默认Context
所有无法和其它Context的路径名匹配的请求都将最终和该默认Context匹配

1.6 - Context

一个Context对应于一个Web Application,一个Web Application由一个或者多个Servlet组成
Context在创建的时候将根据配置文件$CATALINA_HOME/conf/web.xml和$WEBAPP_HOME/WEB-INF/web.xml载入Servlet类
当Context获得请求时,将在自己的映射表(mapping table)中寻找相匹配的Servlet类
如果找到,则执行该类,获得请求的回应,并返回

2 - Tomcat Server的结构图

3 - 配置文件$CATALINA_HOME/conf/server.xml的说明

该文件描述了如何启动Tomcat Server

[html]  view plain copy
  1. <!----------------------------------------------------------------------------------------------->  
  2.   
  3.   
  4.   
  5. <!-- 启动Server  
  6.      在端口8005处等待关闭命令  
  7.      如果接受到"SHUTDOWN"字符串则关闭服务器  
  8.      -->  
  9.   
  10. <Server port="8005" shutdown="SHUTDOWN" debug="0">  
  11.   
  12.   
  13.   <!-- Listener ???  
  14.        目前没有看到这里  
  15.        -->  
  16.   
  17.   <Listener className="org.apache.catalina.mbeans.ServerLifecycleListener" debug="0"/>  
  18.   <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" debug="0"/>  
  19.   
  20.   
  21.   <!-- Global JNDI resources ???  
  22.        目前没有看到这里,先略去  
  23.        -->  
  24.   
  25.   <GlobalNamingResources>  
  26.     ... ... ... ...  
  27.   </GlobalNamingResources>  
  28.   
  29.   
  30.   <!-- Tomcat的Standalone Service  
  31.        Service是一组Connector的集合  
  32.        它们共用一个Engine来处理所有Connector收到的请求  
  33.        -->  
  34.   
  35.   <Service name="Tomcat-Standalone">  
  36.   
  37.   
  38.     <!-- Coyote HTTP/1.1 Connector  
  39.          className : 该Connector的实现类是org.apache.coyote.tomcat4.CoyoteConnector  
  40.          port : 在端口号8080处侦听来自客户browser的HTTP1.1请求  
  41.          minProcessors : 该Connector先创建5个线程等待客户请求,每个请求由一个线程负责  
  42.          maxProcessors : 当现有的线程不够服务客户请求时,若线程总数不足75个,则创建新线程来处理请求  
  43.          acceptCount : 当现有线程已经达到最大数75时,为客户请求排队  
  44.                        当队列中请求数超过100时,后来的请求返回Connection refused错误  
  45.          redirectport : 当客户请求是https时,把该请求转发到端口8443去  
  46.          其它属性略  
  47.          -->  
  48.   
  49.     <Connector className="org.apache.coyote.tomcat4.CoyoteConnector"   
  50.                port="8080"   
  51.                minProcessors="5" maxProcessors="75" acceptCount="100"   
  52.                enableLookups="true"   
  53.                redirectPort="8443"   
  54.                debug="0"   
  55.                connectionTimeout="20000"   
  56.                useURIValidationHack="false"   
  57.                disableUploadTimeout="true" />  
  58.   
  59.   
  60.     <!-- Engine用来处理Connector收到的Http请求  
  61.          它将匹配请求和自己的虚拟主机,并把请求转交给对应的Host来处理  
  62.          默认虚拟主机是localhost  
  63.          -->  
  64.   
  65.     <Engine name="Standalone" defaultHost="localhost" debug="0">  
  66.       
  67.   
  68.       <!-- 日志类,目前没有看到,略去先 -->  
  69.   
  70.       <Logger className="org.apache.catalina.logger.FileLogger" .../>  
  71.   
  72.       <!-- Realm,目前没有看到,略去先 -->  
  73.   
  74.       <Realm className="org.apache.catalina.realm.UserDatabaseRealm" .../>  
  75.   
  76.   
  77.       <!-- 虚拟主机localhost  
  78.            appBase : 该虚拟主机的根目录是webapps/  
  79.            它将匹配请求和自己的Context的路径,并把请求转交给对应的Context来处理  
  80.            -->  
  81.   
  82.       <Host name="localhost" debug="0" appBase="webapps" unpackWARs="true" autoDeploy="true">  
  83.         
  84.   
  85.         <!-- 日志类,目前没有看到,略去先 -->  
  86.   
  87.         <Logger className="org.apache.catalina.logger.FileLogger" .../>  
  88.         
  89.   
  90.         <!-- Context,对应于一个Web App  
  91.              path : 该Context的路径名是"",故该Context是该Host的默认Context  
  92.              docBase : 该Context的根目录是webapps/mycontext/  
  93.              -->  
  94.   
  95.         <Context path="" docBase="mycontext" debug="0"/>  
  96.           
  97.   
  98.         <!-- 另外一个Context,路径名是/wsota -->  
  99.   
  100.         <Context path="/wsota" docBase="wsotaProject" debug="0"/>  
  101.                
  102.           
  103.       </Host>  
  104.         
  105.     </Engine>  
  106.   
  107.   </Service>  
  108.   
  109. </Server>  
  110.   
  111.   
  112. <!----------------------------------------------------------------------------------------------->  


 

4 - Context的部署配置文件web.xml的说明

一个Context对应于一个Web App,每个Web App是由一个或者多个servlet组成的
当一个Web App被初始化的时候,它将用自己的ClassLoader对象载入“部署配置文件web.xml”中定义的每个servlet类
它首先载入在$CATALINA_HOME/conf/web.xml中部署的servlet类
然后载入在自己的Web App根目录下的WEB-INF/web.xml中部署的servlet类
web.xml文件有两部分:servlet类定义和servlet映射定义
每个被载入的servlet类都有一个名字,且被填入该Context的映射表(mapping table)中,和某种URL PATTERN对应
当该Context获得请求时,将查询mapping table,找到被请求的servlet,并执行以获得请求回应

分析一下所有的Context共享的web.xml文件,在其中定义的servlet被所有的Web App载入

[html]  view plain copy
  1. <!----------------------------------------------------------------------------------------------->  
  2.   
  3.   
  4. <web-app>  
  5.   
  6.   
  7.   <!-- 概述:  
  8.        该文件是所有的WEB APP共用的部署配置文件,  
  9.        每当一个WEB APP被DEPLOY,该文件都将先被处理,然后才是WEB APP自己的/WEB-INF/web.xml  
  10.        -->  
  11.   
  12.   
  13.   
  14.   <!--  +-------------------------+  -->  
  15.   <!--  |    servlet类定义部分    |  -->  
  16.   <!--  +-------------------------+  -->  
  17.   
  18.     
  19.   
  20.   <!-- DefaultServlet  
  21.        当用户的HTTP请求无法匹配任何一个servlet的时候,该servlet被执行  
  22.        URL PATTERN MAPPING : /  
  23.        -->  
  24.   
  25.     <servlet>  
  26.         <servlet-name>default</servlet-name>  
  27.         <servlet-class>  
  28.           org.apache.catalina.servlets.DefaultServlet  
  29.         </servlet-class>  
  30.         <init-param>  
  31.             <param-name>debug</param-name>  
  32.             <param-value>0</param-value>  
  33.         </init-param>  
  34.         <init-param>  
  35.             <param-name>listings</param-name>  
  36.             <param-value>true</param-value>  
  37.         </init-param>  
  38.         <load-on-startup>1</load-on-startup>  
  39.     </servlet>  
  40.   
  41.   
  42.   <!-- InvokerServlet  
  43.        处理一个WEB APP中的匿名servlet  
  44.        当一个servlet被编写并编译放入/WEB-INF/classes/中,却没有在/WEB-INF/web.xml中定义的时候  
  45.        该servlet被调用,把匿名servlet映射成/servlet/ClassName的形式  
  46.        URL PATTERN MAPPING : /servlet/*  
  47.        -->  
  48.   
  49.     <servlet>  
  50.         <servlet-name>invoker</servlet-name>  
  51.         <servlet-class>  
  52.           org.apache.catalina.servlets.InvokerServlet  
  53.         </servlet-class>  
  54.         <init-param>  
  55.             <param-name>debug</param-name>  
  56.             <param-value>0</param-value>  
  57.         </init-param>  
  58.         <load-on-startup>2</load-on-startup>  
  59.     </servlet>  
  60.   
  61.   
  62.   <!-- JspServlet  
  63.        当请求的是一个JSP页面的时候(*.jsp)该servlet被调用  
  64.        它是一个JSP编译器,将请求的JSP页面编译成为servlet再执行  
  65.        URL PATTERN MAPPING : *.jsp  
  66.        -->  
  67.   
  68.     <servlet>  
  69.         <servlet-name>jsp</servlet-name>  
  70.         <servlet-class>org.apache.jasper.servlet.JspServlet</servlet-class>  
  71.         <init-param>  
  72.             <param-name>logVerbosityLevel</param-name>  
  73.             <param-value>WARNING</param-value>  
  74.         </init-param>  
  75.         <load-on-startup>3</load-on-startup>  
  76.     </servlet>  
  77.   
  78.   
  79.   
  80.   <!--  +---------------------------+  -->  
  81.   <!--  |    servlet映射定义部分    |  -->  
  82.   <!--  +---------------------------+  -->  
  83.   
  84.       
  85.     <servlet-mapping>  
  86.         <servlet-name>default</servlet-name>  
  87.         <url-pattern>/</url-pattern>  
  88.     </servlet-mapping>  
  89.   
  90.     <servlet-mapping>  
  91.         <servlet-name>invoker</servlet-name>  
  92.         <url-pattern>/servlet/*</url-pattern>  
  93.     </servlet-mapping>  
  94.   
  95.     <servlet-mapping>  
  96.         <servlet-name>jsp</servlet-name>  
  97.         <url-pattern>*.jsp</url-pattern>  
  98.     </servlet-mapping>  
  99.   
  100.   
  101.   <!--  +------------------------+  -->  
  102.   <!--  |    其它部分,略去先    |  -->  
  103.   <!--  +------------------------+  -->  
  104.   
  105.     ... ... ... ...  
  106.   
  107. </web-app>  
  108.   
  109.   
  110. <!----------------------------------------------------------------------------------------------->  


5 - Tomcat Server处理一个http请求的过程

假设来自客户的请求为:
http://localhost:8080/wsota/wsota_index.jsp

1) 请求被发送到本机端口8080,被在那里侦听的Coyote HTTP/1.1 Connector获得
2) Connector把该请求交给它所在的Service的Engine来处理,并等待来自Engine的回应
3) Engine获得请求localhost/wsota/wsota_index.jsp,匹配它所拥有的所有虚拟主机Host
4) Engine匹配到名为localhost的Host(即使匹配不到也把请求交给该Host处理,因为该Host被定义为该Engine的默认主机)
5) localhost Host获得请求/wsota/wsota_index.jsp,匹配它所拥有的所有Context
6) Host匹配到路径为/wsota的Context(如果匹配不到就把该请求交给路径名为""的Context去处理)
7) path="/wsota"的Context获得请求/wsota_index.jsp,在它的mapping table中寻找对应的servlet
8) Context匹配到URL PATTERN为*.jsp的servlet,对应于JspServlet类
9) 构造HttpServletRequest对象和HttpServletResponse对象,作为参数调用JspServlet的doGet或doPost方法
10)Context把执行完了之后的HttpServletResponse对象返回给Host
11)Host把HttpServletResponse对象返回给Engine
12)Engine把HttpServletResponse对象返回给Connector
13)Connector把HttpServletResponse对象返回给客户browser


http://chatgpt.dhexx.cn/article/w4A9XjZV.shtml

相关文章

Tomcat的原理及架构

转自&#xff1a;https://zhuanlan.zhihu.com/p/35398064 俗话说&#xff0c;站在巨人的肩膀上看世界&#xff0c;一般学习的时候也是先总览一下整体&#xff0c;然后逐个部分个个击破&#xff0c;最后形成思路&#xff0c;了解具体细节&#xff0c;Tomcat的结构很复杂&#xf…

Tomcat基本原理

1.Tomcat核心&#xff1a; Http服务器Servlet容器 组件分工&#xff1a; 连接器Connector&#xff1a;处理 Socket 连接&#xff0c;负责网络字节流与 Request 和 Response 对象的转化。容器Container&#xff1a;加载和管理 Servlet&#xff0c;以及具体处理 Request 请求。 …

tomcat的工作原理

本文源自转载&#xff1a;你还记得 Tomcat 的工作原理么 一、Tomcat 整体架构 Tomcat 是一个免费的、开源的、轻量级的 Web 应用服务器。适合在并发量不是很高的中小企业项目中使用。 二、文件目录结构 以下是 Tomcat 8 主要目录结构 三、功能组件结构 Tomcat 的核心功能有…

Tomcat原理整理

目录接口 功能组件 Tomcat 的核心功能有两个&#xff0c;分别是负责接收和反馈外部请求的连接器 Connector&#xff0c;和负责处理请求的容器 Container。其中连接器和容器相辅相成&#xff0c;多个 Connector 和一个 Container 一起构成了基本的 web 服务 Service。每个 Serve…

Tomcat工作原理详细介绍

大部分企业的 Web 应用都运行在它上面&#xff0c;Tomcat 对于程序员来说算是老朋友了&#xff0c;那么今天带大家走近这位老朋友&#xff0c;看看它是如何处理 Web 请求&#xff0c;以及它内部的体系结构&#xff0c;这对帮助我们理解 Tomcat 的使用大有益处。 本文你将会学会…

Tomcat原理

Tomcat顶层架构 Tomcat的顶层结构图&#xff1a; 1、Tomcat中最顶层的容器是Server&#xff0c;代表着整个服务器&#xff0c;一个Server可以包含至少一个Service&#xff0c;用于具体提供服务。 2、Service主要包含两个部分&#xff1a;Connector和Container。 Tomcat 的心脏…

javascript 文本框限制输入1到10位数字正则表达式

<meta http-equiv"Content-Type" content"text/html; charsetUTF-8"> <!DOCTYPE html> <html> <head><title>DOM 教程</title><style></style><!--不需要再次引用jquery--><script type"te…

js数字正则

js正则表达式 1.了解什么是正则表达式&#xff1f; 正则表达式&#xff08;Regular Expression&#xff09;又称规则表达式&#xff0c;简单来说它就是一个概念&#xff0c;用事先声明好的字符和字符的组合&#xff0c;来组成一个“规则字符串”&#xff0c;用来检测我们书写…

卷积神经网络降维方法,深度神经网络降维方法

1、卷积神经网络中用1*1 卷积有什么作用或者好处 1*1卷积的主要作用有以下几点&#xff1a; 1、降维&#xff08; dimension reductionality &#xff09;。比如&#xff0c;一张500 * 500且厚度depth为100 的图片在20个filter上做1*1的卷积&#xff0c;那么结果的大小为500*5…

常用降维方法

降维方法分为线性核非线性降维&#xff0c;非线性降维又分为基于核函数和基于特征值的方法。 线性降维方法&#xff1a;PCA ICA LDA LFA LPP(LE的线性表示) 基于核函数的非线性降维方法&#xff1a;KPCA KICA KDA 基于特征值的非线性降维方法&#xff08;流型学习&#x…

机器学习四大数据降维方法详解

引言&#xff1a; 机器学习领域中所谓的降维就是指采用某种映射方法&#xff0c;将原高维空间中的数据点映射到低维度的空间中。降维的本质是学习一个映射函数 f : x->y&#xff0c;其中x是原始数据点的表达&#xff0c;目前最多使用向量表达形式。 y是数据点映射后的低维向…

机器学习 | 降维问题

目录 一、主成分分析 二、奇异值分解 2.1 奇异值分解原理 2.2 奇异值分解实践 三、特征值与特征向量 一、主成分分析 主成分有如下特征&#xff1a; 每个主成分是原变量的线性组合&#xff1b;各个主成分之间互不相关&#xff1b;主成分按照方差贡献率从大到小依次排列&…

数据降维方法总结

Introduce 经过这几天面试后&#xff0c;我发现数据降维这一块在工业界用的很多或者说必不可少&#xff0c;因此&#xff0c;这方面需要重点关注。今天&#xff0c;我将数据降维总结于此&#xff0c;包括他人成果&#xff0c;这里对他们的内容表示感谢。 Method 对数据降维作…

机器学习四大降维方法

引言&#xff1a; 机器学习领域中所谓的降维就是指采用某种映射方法&#xff0c;将原高维空间中的数据点映射到低维度的空间中。降维的本质是学习一个映射函数 f : x->y&#xff0c;其中x是原始数据点的表达&#xff0c;目前最多使用向量表达形式。 y是数据点映射后的低维向…

机器学习降维方法概括

最近刷题看到特征降维相关试题&#xff0c;发现自己了解的真是太少啦&#xff0c;只知道最简单的降维方法&#xff0c;这里列出了常见的降维方法&#xff0c;有些算法并没有详细推导。特征降维方法包括&#xff1a;Lasso&#xff0c;PCA&#xff0c;小波分析&#xff0c;LDA&am…

详解机器学习高维数据降维方法

当特征选择完成后&#xff0c;可以直接训练模型了&#xff0c;但是可能由于特征矩阵过大&#xff0c;导致计算量大&#xff0c;训练时间长的问题&#xff0c;因此降低维度也是必不可少的。 常见的降维方法除了以上提到的基于 L1 惩罚项的模型以外&#xff0c;另外还有主成分分…

机器学习之降维

本周关于降维的学习主要分为五类&#xff1a;PCA、LDA、LLE、tSNE、ISOMAP 来进行学习 首先自己的任务是&#xff1a;tSNE的学习 &#xff08;一&#xff09;降维的基本知识点总结 1、降维方法分为线性和非线性降维&#xff0c;非线性降维又分为基于核函数和基于特征值的方…

四大机器学习降维方法

引言&#xff1a; 机器学习领域中所谓的降维就是指采用某种映射方法&#xff0c;将原高维空间中的数据点映射到低维度的空间中。降维的本质是学习一个映射函数 f : x->y&#xff0c;其中x是原始数据点的表达&#xff0c;目前最多使用向量表达形式。 y是数据点映射后的低维向…

降维方法总结

目录 数据降维方法: 降维&#xff1a; 降维的用处&#xff1a; 降维方法思想分类&#xff1a; 降维方法总览 降维方法详细说明 1. 缺失值比率&#xff08;Missing Value Ratio&#xff09; 2. 低方差滤波&#xff08;Low Variance Filter&#xff09; 3. 高相关…

数据分析七种降维方法

近来由于数据记录和属性规模的急剧增长&#xff0c;大数据处理平台和并行数据分析算法也随之出现。于此同时&#xff0c;这也推动了数据降维处理的应用。实际上&#xff0c;数据量有时过犹不及。有时在数据分析应用中大量的数据反而会产生更坏的性能。 最新的一个例子是采用 20…