《深入拆解Tomcat&Jetty》总结一:Web服务器的前导知识之HTTP和Servlet规范

1 HTTP和Tomca/Jetty的关系


Tomcat/Jetty本质:HTTP服务器 + Servlet容器

HTTP请求过程:

补充:Tomcat的Session管理器提供了多种持久化方案来存储Session,通常会采用高性能的存储方式,比如Redis,并且通过集群部署的方式,防止单点故障,从而提升高可用。
同时,Session有过期时间,因此Tomcat会开启后台线程定期的轮询,如果Session过期了就将Session失效。

2 Servlet规范


Servlet容器用来HTTP服务器和业务类之间的解耦,而Servlet接口则是Servlet容器跟具体业务类之间的接口:

 

工作流程:

HTTP服务器会用一个ServletRequest对象把客户的请求信息封装起来,然后调用Servlet容器的service方法;Servlet容器拿到请求后,根据请求的URL和Servlet的映射关系,找到相应的Servlet,如果Servlet还没有被加载,就用反射机制创建这个Servlet,并调用Servlet的init方法来完成初始化;
接着调用Servlet的service方法来处理请求,把ServletResponse对象返回给HTTP服务器,HTTP服务器会把响应发送给客户端:


Servlet注册到Servlet容器的方式:

以Web应用程序的方式来部署Servlet;
根据Servlet规范,Web应用程序有一定的目录结构,在这个目录下分别放置了Servlet的类文件、配置文件以及静态资源,Servlet容器通过读取配置文件,就能找到并加载Servlet。

Servlet规范里定义了ServletContext这个接口来对应一个Web应用。
Web应用部署好后,Servlet容器在启动时会加载Web应用,并为每个Web应用创建唯一的ServletContext对象。
你可以把ServletContext看成是一个全局对象,一个Web应用可能有多个Servlet,这些Servlet可以通过全局的ServletContext来共享数据,这些数据包括Web应用的初始化参数、Web应用目录下的文件资源等。
由于ServletContext持有所有Servlet实例,可以通过它来实现Servlet请求的转发。

SpringMVC 容器是管理controller对象的,在DispatcherServlet中init方法里创建

扩展机制:
如果Servlet规范不能满足业务的个性化需求,就有问题了,因此设计一个规范或者一个中间件,要充分考虑到可扩展性;
Servlet规范提供了两种扩展机制:Filter和Listener。

Filter的工作原理:Web应用部署完成后,Servlet容器需要实例化Filter并把Filter链接成一个FilterChain。当请求进来时,获取第一个Filter并调用doFilter方法,doFilter方法负责调用这个FilterChain中的下一个Filter。

Listener工作原理:观察者模式,当被观察者的某个状态改变时,调用所有观察者的方法进行响应

Filter和Listener的本质区别:
Filter是干预过程的,它是过程的一部分,是基于过程行为的。
Listener是基于状态的,任何行为改变同一个状态,触发的事件是一致的。

对比:Spring容器、SpringMVC容器、Servlet容器的关系?

Spring容器是管理Service和Dao的,SpringMVC容器是管理Controller对象的,Servlet容器是管理servlet对象的。

Spring容器和Servlet容器没关系,而SpringMVC容器里面存放的Controller类是通过自定义出来的DispatcherServlet(继承自Servlet)+反射机制来访问的

日志:Tomcat安装目录下的logs目录
Tomcat的日志信息分为两类 :一是运行日志,它主要记录运行过程中的一些信息,尤其是一些异常错误日志信息 ;
二是访问日志,它记录访问的时间、IP地址、访问的路径等相关信息。

catalina.***.log:主要是记录Tomcat启动过程的信息,在这个文件可以看到启动的JVM参数以及操作系统等日志信息。

catalina.out:catalina.out是Tomcat的标准输出(stdout)和标准错误(stderr),这是在Tomcat的启动脚本里指定的,
如果没有修改的话stdout和stderr会重定向到这里。所以在这个文件里可以看到我们在Servlet程序里打印出来的信息

localhost.**.log:主要记录Web应用在初始化过程中遇到的未处理的异常,会被Tomcat捕获而输出这个日志文件。

localhost_access_log.**.txt:存放访问Tomcat的请求日志,包括IP地址以及请求的路径、时间、请求协议以及状态码等信息。

manager.***.log/host-manager. ***.log:存放Tomcat自带的manager项目的日志信息。
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值