类名 | org.apache.catalina.core.StandardService |
继承关系 | LifecycleMBeanBase Service |
关联类 | Container Connector Excecutor |
实现功能 | 管理子组件 |
分析
从这节开始,我们就真正进入了对开发人员来说至关重要的一些内容,Connector,Container以及Excecutor。而所有这些,都是被StandardService类管理和维护的。
Connector
Tomcat官方对于Connector的定义这样的:A "Connector" represents an endpoint by which requests are。 received and response are returned. 也就是说,Connector是Tomcat接受Request和发送response的端口。
Tomcat目前支持两种Connector:
HTTP Connector
Http Connector顾名思义,是Tomcat用来接收HTTP Request和发送HTTP Response的端口,支持HTTP/1.1协议。正是因为拥有了HTTP Connector, Tomcat得以处理servlet和JSP页面,并可以被用作独立的web Server。而HTTP Connector监听server上的某个端口,并将request发送到后台的Engine中进行处理,并返回response.
对于每一个request, Connector都会使用一个单独的线程来处理。如果request数量大于线程数量,Connector就会创建更多的线程,直到达到峰值。后面再来的request就会被丢弃。(拒绝服务攻击就是基于这样的原理)
Tomcat7中使用的HTTP Connector的代号是Coyote.
AJP Connector
相应的,AJP Connector支持AJP协议,其通常被用于两个web connector之间的通讯。
常用的case是当你希望将Tomcat集成到Apache中时,你希望Apache帮你处理静态内容,而Tomcat专注于动态内容时,AJP Connector便可以从中协调。
Executor
Executor是一个可以在Tomcat各个组件中共享的线程池。Tomcat在过去版本中,曾经有过各个组件拥有自己的线程池,但现在你可以用Executor在各个组件中共享,提高性能。
Container
Tomcat 7中包含以下几种Container:
Context
一个Context代表了一个web application. 而根据Sevlet Specification中的描述,WAR包或者具有WAR包文件结构的文件夹都可以被认为是一个web application. 因此,对于部署在Tomcat中的每一个应用,都相应的是一个Context.
任何一个Context都包含在一个Host中。
Engine
Engine包含了整个request机制的流程,当Connector接收到request后,就发送给Engine来处理。
Host
Host是一台虚拟主机,一个虚拟主机会拥有一个独立的网络服务器名,这个名字会在DNS上注册并供客户访问使用。
任何一个host都包含在Engine中。
Cluster
Tomcat的cluster提供了会话复制,上下文属性复制已经全局WAR包部署等功能。我们可以通过配置Cluster来实现负载均衡。