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项目的日志信息。