因为Tomcat 本身就是一个“HTTP 服务器 + Servlet容器”,所以这一节先对HTTP工作原理进行一下回顾。
HTTP的本质
HTTP协议是浏览器和服务器之间的数据传输协议,主要规定了客户端和服务器之间的通信格式。
当浏览器需要从服务器上获取信息的时候,实际上经历了两个过程:
- 与服务器简历socket链接
- 生成请求数据并通过socket链接发送过去
HTTP协议其实就是在浏览器和服务器之间约定好通信格式的。这样服务器就可以通过约定好的格式来分析出浏览器想要获取数据还是上传数据。传过来的数据格式是什么样的。
HTTP 工作原理
image.png
- 用户通过浏览器发送一个请求,浏览器获取了这个事件
- 浏览器通过TCP协议向服务器发送请求
- 服务器接受请求,通过TCP三次握手建立连接
- 浏览器将请求数据打包成HTTP协议个数的数据包
- 服务器程序拿到数据包,同样使用HTTP协议解析数据包,获得客户端的意图
- 服务器执行相关代码,得到结果
- 服务器将相应数据推入网络,数据包通过网络传输最终到达浏览器
- 浏览器拿到数据包通过HTTP协议解析包,然后解析数据(展示或者...)
我们主要考虑Tomcat 在这个过程中作为一个HTTP服务器都做了什么事情?主要就是接受连接、解析请求数据、处理请求和发送响应数据这四个部分。Tomcat 为了提高服务能力和并发能力,在这几个步骤中往往都是并行执行的,具体实现方式就是使用了线程池技术。
在服务器接受请求时,Tomcat 会把HTTP请求数据字节流解析成一个Request对象,这个Request对象封装了HTTP请求的所有信息。Tomcat把这个Request对象传递给Web应用去进行业务处理,处理完成后得到一个Response对象,Tomcat会把Response对象转化成HTTP格式的响应数据并发送给浏览器。