浏览器访问流程
HTTP请求的处理流程如下:
浏览器访问服务器使用的是HTTP协议,HTTP是应用层的协议,用于定义数据通信的格式,具体的数据传输使用的是TCP/IP协议。
- 用户输入 URL:用户在浏览器地址栏输入例如 https://www.example.com
- URL 解析:浏览器将 URL 分解为协议、主机名、路径、端口
- DNS 解析:浏览器向本地 DNS 服务器查询 IP 地址
- 建立 TCP 连接(三次握手)
- (HTTPS专属)进行 TLS 握手
- 浏览器发送 HTTP 请求
- 服务器处理请求并返回响应
- 浏览器渲染页面
整体架构
大致流程
Tomcat 是一个 HTTP 服务器,我们使用浏览器向某一个网站发起请求,发出HTTP请求,那么在远程,HTTP服务器接收到这个请求之后,会调用具体的程序(Java类)进程处理,往往不同的请求由不同的Java类进行处理。
HTTP服务器接收到请求之后把请求交给 Servlet 容器来处理,Servlet容器通过Servlet接口调用业务的类,Servlet接口和Servlet容器这一整套内容叫做Servlet规范。
Tomcat既按照Servlet规范的要求去实现了Servlet容器,同时它也具有HTTP服务器的功能。
容器处理流程
当用户访问某个URL资源时:
- HTTP服务器会把请求信息使用ServletRequest对象封装起来
- 进一步去调用Servlet容器中某个具体的Servlet
- 在2中,Servle容器拿到请求之后,根据URL和Servlet的映射关系,找到相应的Servlet
- 如果Servlet还没有被加载,就用反射机制创建这个Servlet,并调用Servlet的init方法来完成对象的初始化
- 接着调用这个具体的Servlet的service方法来处理请求,请求处理结果使用ServletResponse对象封装
- 把ServletResponse 对象返回给HTTP服务器,HTTP服务器会把响应发送给客户端
总体架构
通过上面的讲解,我们发现Tomcat有两个非常重要的功能需要完成:
- 和客户端浏览器进行交互,通过Socket通信,将字节流和Request、Response等对象进行转化
- Servlet容器处理业务逻辑
Tomcat设计了两个核心组件:
- 连接器(Connector):负责对外交流,处理Socket连接,负责网络字节流与Request、Response对象的转化
- 容器(Container):加载和管理Servlet,以及具体处理Request请求
连接器组件 Coyote
Coyote 是 Tomcat 中连接器的组件名称,是对外的接口,客户端通过 Coyote 与服务器建立连接、发送请求并接受响应。
- Coyote 封装了底层的网络通信(Socket请求及响应处理)
- Coyote 使 Catalina 容器(容器组件)与具体的请求协议及IO操作方式完全解耦
- Coyote 将 Socket 输入转换封装为 Request 对象,进一步封装后交由 Catalina 容器进行处理,处理请求完成后,Catalina 通过 Coyote 提供的 Response 对象将结果写入输出流
- Coyote 负责的是具体协议(应用层)和 IO(传输层)相关内容
Coyote 支持 IO 模型与协议
在 8.0 之前,Tomcat默认采用的是 I/O方式 BIO,之后改为 NIO。无论是 NIO、NIO2、APR,在性能方面优于以往的 BIO。如果采用 APR,甚至可以达到 Apache HTTP Server 的性能。