tomcat知识点讲解

tomcat的请求处理流程:

tomcat就是servlet容器,tomcat只关心servlet。去将servlet和url-Pattern进行匹配。

项目打包war包,去tomcat中部署.去webapps文件夹下将war包解压。去找web.xml文件。

web.xml文件中,找到servlet标签,将servlet标签中的servlet-name和servlet-class进行匹配。

tomcat启动占用一个监听端口,在操作系统之上的字节流会从端口进入到tomcat中。

然后去匹配url,找到项目中的servlet。

tomcat四大容器:

1.Engine:直接理解为一个tomcat即可,一个tomcat一个engine

List<Host> hosts

defaultHost:指定默认主机

2.Host:一个Host表示一个虚拟服务器,可以给每个Host配置一个域名

List<Context> contexts

conf下的server.xml

Host下的属性:

name就是域名地址,appBase就是应用的目录,unpackWARs是否解压war包,

<Context>中的属性path就是路径,docBase就是找servlet的路径.

3.Context:一个Context就是一个应用,一个项目

List<Wrapper> wrappers.一个应用下有多个servlet.

去找webapps下的目录,一个目录一个应用

web.xml

4.Wrapper:一个wrapper表示一个Servlet的包装.

List<Servlet> servlets.该下存的servlet都是同一个类型的.

比如说:AServlet-->Wrapper对象-->4AServlet实例。将实例存到wrapper对象中去。

编写servlet部署到tomcat中去,该类产生请求肯定会产生具体的实例,通过实例对象调用方法

在编写一个servlet时继承HttpServlet,所有请求公用一个servlet实例-->线程不安全

这个时候添加一个属性i,每次使用方法让i++,称为状态。

可以通过实现implements SingleThreadModel.使得每个请求单独使用一个Servlet实例-->线程安全

四个容器有层次结构关系:一个Engine下有多个Host,一个Host可以有多个Context,

一个Context下可以有多个Wrapper,一个Wrapper可以有多个Servlet实例对象。

总而言之,一个servlet对应一个wrapper对象,创建多个servlet实例,将多个servlet实例存到

wrapper中[List<Servlet> servlets]。然后[List<Wrapper> wrappers]

List\ contexts\],\[ist\ hosts\]. tomcat的四大容器中每个容器还有两个属性,每个容器下有pipeline管道属性,管道属性下有valve阀门属性。 ## tomcat容器请求处理流程: 首先发送一个请求,http/ip地址/端口号/...路径。请求包括请求方法,url,协议版本,servletName.发送 请求之后由Adapter接受请求,生成request对象,找到该请求所对应的host,context,wrapper,设值给request, 然后找到engine的Pipeline中的第一个valve并执行。依次执行valve后执行到StandardEngineValve, StandardEngineValve的作用就是找到host的第一个valve。依次按照容器层级结构进行执行。直到最后的wrapper容器, 其中的StandardWrapperValve方法作用是找到对应的servlet实例并调用service方法。Servlet实例.service(request,response) ## 字节流--\>HttpServletRequest req? 字节流怎么来的,浏览器发送的http请求,在浏览器虽然输入的只有路径字符串, 但是访问端口8080之后访问的数据不只路径字符串,而是http协议的数据格式,发送一个http请求, 浏览器将输入的路径字符串转换成字节流,将http协议的数据转换成字节,然后在通过网络发送出去。 tomcat所接收到的字节流其实就是http协议翻译过来的字节流。 tomcat接收到之后同样用http协议的格式去解析字节流。 通常进行socket长连接的时候,发送给tomcat多个请求,此时字节流中第一个请求的请求体和第二个请求的 请求行是连着的,我们通过Context-Length来判断哪一部分是请求体,哪一部分是请求行。 在第一个请求的请求头之中,附带上Context-Length来告诉请求体有多长,这样就能判断了。 除了这个方法还有一个方法使用分块传输。 IO模型 线程模型 BIO: 传统的IO模型,称为同步阻塞IO。服务器实现模式为一个连接一个线程,即客户端有请求的时候服务端就要启动一个线程进行处理。 NIO: 同步非阻塞IO,基于事件驱动处理IO操作,NIO主要组成部分为选择器,缓冲区,通道。通道是一个可以进行数据读写的对象, 所有数据通过缓存处理,使用选择器和通道可以在单个线程上执行多个连接。 AIO: 异步非阻塞IO模型。对于socket和IO操作都是异步的,不会阻塞任何线程。 JIO:除非在tomcat启动时找到了APR库,否则这是tomcat默认的连接方法。 APR?

相关推荐
毕业设计制作和分享2 小时前
springboot150基于springboot的贸易行业crm系统
java·vue.js·spring boot·后端·毕业设计·mybatis
小梁努力敲代码7 小时前
java数据结构--List的介绍
java·开发语言·数据结构
摸鱼的老谭7 小时前
构建Agent该选Python还是Java ?
java·python·agent
lang201509288 小时前
Spring Boot 官方文档精解:构建与依赖管理
java·spring boot·后端
夫唯不争,故无尤也8 小时前
Tomcat 启动后只显示 index.jsp,没有进入你的 Servlet 逻辑
java·servlet·tomcat
zz-zjx8 小时前
Tomcat核心组件全解析
java·tomcat
Deschen8 小时前
设计模式-外观模式
java·设计模式·外观模式
why技术9 小时前
从18w到1600w播放量,我的一点思考。
java·前端·后端
夫唯不争,故无尤也9 小时前
JavaWeb流式传输速查宝典
java·流式传输
苏小瀚10 小时前
算法---位运算
java·算法