深入拆解Tomcat&Jetty(三)

Servlet规范和Servlet容器

由HTTP请求过程可以知道,HTTP服务器收到请求后,需要调用服务端程序进行处理,所谓的服务端程序就是开发人员编写的Java类,一般来说不同的请求需要由不同的Java类进行处理,而HTTP并不知道要调用哪个Java类的哪个方法,所以就有了Servlet接口.

虽然有了Servlet接口,将具体实现交由业务方处理,但是对于特定的请求,HTTP服务器是无法知道由哪个Servlet进行处理的,所有又有了Servlet容器,Servlet容器用来加载和管理业务类.将HTTP请求交由Servlet容器去处理,容器根据请求转发到具体的Servlet,如果Servlet没有创建则进行实例化,然后调用这个Servlet的接口方法.Servlet接口其实是Servlet容器跟具体业务类之间的接口

Servlet容器处理HTTP请求

可以看到Tomcat通过Servlet容器将HTTP请求具体的业务处理进行了解耦,容器通过Servlet接口调用业务类.而Servlet接口和Servlet容器这一套规范就做Servlet规范.

Tomcat和Jetty都按照Servlet规范的要求实现了Servlet容器,同时它们也具备HTTP服务器的功能.

Servlet接口

javax.servlet.Servlet5个方法

public interface Servlet {
    void init(ServletConfig config) throws ServletException;
    ServletConfig getServletConfig();
    void service(ServletRequest req, ServletResponse res)throws ServletException, IOException;
    String getServletInfo();
    void destroy();
}

其中最重要的是service方法,具体业务类在这个方法里面实现逻辑处理.这个方法的两个参数ServletRequestServletResponse,其中ServletRequest用来封装请求信息,ServletResponse用来封装响应信息.本质上这两个类是对通信协议的封装.

SpringMVC中的DispatcherServlet在init方法创建了自己的Spring容器.

Servlet容器

Servlet容器主要关注两个内容

  • Web应用的目录格式是什么样的
  • 如何扩展和定制化Servlet容器的功能

工作流程

  • 1.HTTP服务器将请求封装成ServletRequest对象,调用service方法
  • 2.根据请求的URL和Servlet的映射关系,找到相应的Servlet
  • 3.如果Servlet没有被加载,利用反射机制进行创建,并调用init方法完成初始化,然后再调用service方法处理请求
  • 4.将响应内容封装成ServletResponse对象返回给HTTP服务器,将响应发送给客户端


    Servlet工作流程

Web应用

Servlet容器会实例化和调用Servlet,一般来说,我们会以Web应用程序的方式部署Servlet,根据Servlet规范,Web应用程序有一定的目录结构,这个目录结构下分别放置了Servlet类文件,配置文件,静态资源,Servlet容器通过读取配置文件,就能找到Servlet.

Web应用的目录结构

|- WebApp
 |- WEB-INF/web.xml  --配置文件,用来配置Servlet
 |- WEB-INF/lib/        --存放Web应用的各种Jar包 
 |- WEB-INF/classes/ --存放应用类,Servlet类
 |- META-INF/       --存放工程的信息

Servlet规范定义了ServletContext接口对应Web应用.Web应用部署好之后,Servlet容器会在启动时加载Web应用,并为Web应用创建唯一的ServletContext对象.

一个应用只有一个ServletContext,有多个Servlet,Servlet可以通过ServletContext共享数据.由ServletContext持有所有的Servlet实例

扩展机制

Filter&Listener

Filter是过滤器,可以通过过滤器对请求和响应做定制化处理,例如可以根据请求的频率限制访问,根据国家地区不同修改响应内容.

Filter的工作原理

Servlet容器把所有Filter链接成一个FilterChain,当请求进来之后,获取第一个Filter并调用doFilter方法,doFilter方法负责调用FilterChain的下一个方法.这里用到了责任链模式

Listener监听器,当应用在Servlet容器中运行时,Servlet容器内部会不断发生各种事情,如Web应用的启动,停止,用户请求到达等.

Spring实现了自己的监听器,用来监听ServletContext的启动事件,目的是当Servlet容器启动时,创建并初始化全局的Spring容器.

Filter和Listener的本质区别

  • Filter是干预过程的,是过程的一部分,基于过程行为
  • Listenr基于状态,任何行为改变同一个状态,触发的事件是一致的.

ServletContext,Spring,SpringMVC的关系

ServletContext,Spring,SpringMVC的关系
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,590评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,808评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,151评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,779评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,773评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,656评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,022评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,678评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,038评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,756评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,411评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,005评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,973评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,053评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,495评论 2 343

推荐阅读更多精彩内容

  • Servlet接口 Servlet规范的核心接口即是Servlet接口,它是所有Servlet类必须实现的接口,在...
    java日记阅读 1,814评论 0 2
  • IOC 控制反转容器控制程序对象之间的关系,而不是传统实现中,有程序代码之间控制,又名依赖注入。All 类的创建,...
    irckwk1阅读 926评论 0 0
  • 1. ServletContext接口介绍 ServletContext接口定义了servlet运行时Web应用的...
    Lucky_Micky阅读 1,712评论 0 3
  • Servlet技术(上) Tomcat的<CATALINA_HOME>/lib/servlet-api.jar文件...
    So_ProbuING阅读 831评论 0 1
  • 我是极速阅读第一期就加入了,到现在经历了4个月之久,我发现现在自己的人际关系跟朋友圈都发生了改变,里面是一群有理想...
    柔汐之光阅读 264评论 0 0