Servlet 与 Servlet 容器

Servlet 与 Servlet 容器的关系有点像枪和子弹的关系

Tomcat是Servlet容器的一种,Servlet容器可以对Servlet进行管理,控制其生命周期。使其可以专注于自己应该做的事情,不需要考虑端口啊多线程啊socket之类的东西,也使得Servlet在各种环境下具有适应性

Tomcat 的容器等级中,Context容器是直接管理 Servlet 在容器中的包装类 Wrapper

Servlet 与 Servlet 容器

从上图可以看出 Tomcat 的容器分为四个等级,真正管理 Servlet 的容器是 Context 容器,一个 Context容器对应一个 Web 工程(个人理解:容器是说,Context这玩意就是个容器;姑且认为中国Context就是ServletContext)。

一个 Web应用对应一个Context 容器,也就是 Servlet 运行时的 Servlet 容器,添加一个 Web 应用时将会创建一个StandardContext 容器;这个类将会负责整个 Web 应用配置的解析工作,后面将会详细介绍。最后将这个 Context 容器加到父容器 Host 中。

如果你清楚 Tomcat 的系统架构,你会容易理解 Tomcat 的启动逻辑,Tomcat 的启动逻辑是基于观察者模式设计的,所有的容器都会继承 Lifecycle 接口,它管理者容器的整个生命周期,所有容器的的修改和状态的改变都会由它去通知已经注册的观察者(Listener)。

除了将 Servlet 包装成 StandardWrapper 并作为子容器添加到 Context 中,其它的所有 web.xml 属性都被解析到 Context 中,所以说 Context 容器才是真正运行 Servlet 的 Servlet 容器。一个 Web 应用对应一个 Context 容器,容器的配置属性由应用的 web.xml 指定,这样我们就能理解 web.xml 到底起到什么作用了。

 

2.Spring Boot将tomcat设为默认容器,tomcat是一个Servlet容器,所以Spring MVC的入口也毫无意外的是一个Servlet,也就是前置控制器DispatcherServlet,作为Spring MVC架构的核心,前置控制器能够拦截请求,将其分发给Controller处理