Tomcat处理请求的全过程

news2024/11/24 11:04:49

文章目录

  • 一、组件详解
  • 二、请求处理流程
    • 1.总体流程图
    • 2.Worker线程任务流程
  • 三、源码跟踪
    • 1.Tomcat启动线程组件
    • 2.Acceptor
    • 3.Poller
    • 4.Worker
  • 总结


一、组件详解

在Tomcat处理客户端请求的过程中,这里面有三个组件概念,他们都是线程,分别负责不同的职责。
(必须记清楚这三个线程组件)

  • Acceptor

    一个普通线程任务,用于接收新连接,并将新连接封装,选择一个 Poller 将新连接添加到 Poller 的事件队列中。

  • Poller

    一个线程任务,用于监听 Socket 事件,当有任务来临时,将 Socket 封装,添加到 worker 线程池的任务队列中。

  • Worker

    他是创建一组线程的,每个线程任务都是一个阻塞队列,用于对请求进行处理(例如我们中间件参数中的最大线程数就是指最多创建多少个Worker线程)。每个Worker线程任务包括分析解析请求报文、创建 Request 对象、调用容器的 管道pipeline 执行阀门value、执行servlet的具体逻辑。

二、请求处理流程

1.总体流程图

在这里插入图片描述

2.Worker线程任务流程

在这里插入图片描述

三、源码跟踪

1.Tomcat启动线程组件

Tomcat启动时,如果默认使用NIO模式,先是执行了AbstractEndpoint.initServerSocket,通过 ServerSocketChannel.open() 打开一个 ServerSocket通道,默认绑定到 8080 端口,用于监听请求。

说明:在Java语言的NIO中,类ServerSocketChannel就是用来处理TPC连接的客户端,他的open方法就是用例建立一个TPC连接。

在这里插入图片描述

然后Tomcat会创建Worker 线程池、Acceptor线程、Poller线程:

AbstractEndpoint.createExecutor,用于创建 Worker 线程池,这个线程池是用来处理实际的请求的,把配置文件中的初始线程数10、最大线程数200等信息传进去,创建一个线程池executor

在这里插入图片描述

AbstractEndpoint.createExecutor.startAcceptorThread,他创建一个线程任务Acceptor,作为一个接收者,线程用来无限循环接受客户端发送过来的连接请求

在这里插入图片描述

NioEndpoint.startInternal,创建一个线程任务Poller,用于检测Acceptor接兽并处理成已就绪的 Socket。

在这里插入图片描述

2.Acceptor

Tomcat启动完成后,客户端发起一个请求

Acceptor的run方法,无限循环在这里接受连接请求
(假如启动后客户端发起一个请求,这里就是第一时间捕获到)

在这里插入图片描述
点进去NioEndpoint.serverSocketAccept(因为使用NIO模式),可以看到我们熟悉的nio的accept方法,这是一个阻塞的方法,会一直等待接收请求。

在这里插入图片描述

当Acceptor接收到客户端的请求时,调用addEvent() 方法会将 Socket 添加到该 Poller 的 PollerEvent 队列中。并调用了NIO中selector.wakeup方法,唤醒了Poller。到此,这一次请求中 Acceptor 的任务就完成了。

在这里插入图片描述

3.Poller

接着到Poller 线程了,Poller 线程1秒阻塞一次,等待有请求过来被唤醒后,每次请求先过AbstractEndpoint.processSocket

从处理器缓存中获取当前要被执行的任务,放进任务进程,然后获取Worker线程组,将这个任务放进去。到此 Poller 的任务就完成了。

在这里插入图片描述

4.Worker

然后就是到Worker线程组了,这次请求的后续的所有操作都在这个线程中完成。Worker线程是一个阻塞队列,它继承自AbstractQueuedSynchronizer。worker 线程被创建以后就执行 ThreadPoolExecutor 的 runWorker() 方法,试图从 workQueue 中取待处理任务,但是一开始 workQueue 是空的,所以 worker 线程会阻塞在 workQueue.take() 方法。

在这里插入图片描述
当新任务添加到 workQueue后,workQueue.take() 阻塞就会结束,会返回一个 Runnable,通常是 SocketWrapperBase,然后 worker 线程调用 SocketWrapperBase的 run() 方法对 Socket 进行处理。

执行SocketWrapperBase.run

在这里插入图片描述

里面调用的是 doRun方法,他是抽象方法,根据当前Tomcat使用的模式是NIO还是APR去选择执行不同的方法(默认是NIO执行NioEndpoint里的内部类SocketProcessor.doRun)

在这里插入图片描述
这个socket处理器先做TPC的三次握手

在这里插入图片描述

三次握手,这里Tomcat作为服务端,是需要响应(执行)两次的,源码断点发现每次http请求这里都是执行两次

三次握手中该方法执行两次:

第一次执行时event对象是null,执行完是OPEN_READ,表示数据可供客户端读取

第二次执行时event对象是OPEN_READ,如果停用长连接,执行完返回的是CLOSE,关闭连接,否则不关闭
走到下面,他是获取协议处理器,并执行他的process方法

在这里插入图片描述

执行AbstractProtocol.process

可以看到他是获取的Http11Processor,因为默认用的协议是http1.1

在这里插入图片描述
下面执行这个处理器的process方法

在这里插入图片描述

跟进去AbstractProcessorLight.process,然后到了Http11Processor.service,service方法先是从当前请求request中,解析请求行、请求头、请求体,封装成Request对象

在这里插入图片描述

下面获取adapter(CoyoteAdaptor),调用service方法

在这里插入图片描述
执行CoyoteAdaptor.service

获取到Request和Response并封装

在这里插入图片描述

然后调用postParseRequest方法,在 Mapper 中查询 URL 的映射关系

在这里插入图片描述
下面把封装成的Request对象和响应的Response对象传递给Engine容器,然后获取他的管道,执行里面绑定的阀门value

在这里插入图片描述

按顺序执行多个阀门,实现对应的功能

在这里插入图片描述

最后执行到StandardWrapperValve.invoke

在这里插入图片描述
将Servlet封装到FilterChain过滤器链中

在这里插入图片描述

他是定位到ApplicationFilterChain.doFilter,里面先是执行了Tomcat内置的过滤器

在这里插入图片描述
在这里插入图片描述

下面执行了servlet.service

在这里插入图片描述
然后这里就是去调用我们熟悉的HttpServlet的service方法,解析里面对应的doGet方法,或者doPost方法等等… ,也就是执行具体业务方法。

最后由Servlet将响应返回给了客户端。

在这里插入图片描述


总结

欢迎指出我的错误!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/424653.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

NEWS|关于人工智能大型语言模型能否理解的争论

科学家调查了当前人工智能(AI)研究界的一场激烈的争论,即大型预先训练的语言模型是否可以说可以理解语言——以及任何类人意义上的语言编码的物理和社会情境。他们提供了支持和反对这种理解的论点,以及根据这些论点而出现的更广泛…

7个最新的时间序列分析库介绍和代码示例

时间序列分析包括检查随着时间推移收集的数据点,目的是确定可以为未来预测提供信息的模式和趋势。我们已经介绍过很多个时间序列分析库了,但是随着时间推移,新的库和更新也在不断的出现,所以本文将分享8个目前比较常用的&#xff…

SpringCloud学习(六)——Feign的简单使用

文章目录1. Feign 的使用1.1 引入依赖1.2 添加注解1.3 编写Feign客户端1.4 测试2. Feign中的自定义配置2.1.配置文件方式2.2.Java代码方式3. Feign 性能优化4. Feign的抽取式使用4.1 抽取配置4.2 引入依赖4.3 指明Client在此之前,我们服务之间需要进行调用的时候使用…

Spring Cloud Alibaba全家桶(十)——微服务网关Gateway组件

前言 本文小新为大家带来 微服务网关Gateway组件 相关知识,具体内容包括微服务网关Gateway组件(包括:Gateway核心概念,Gateway工作原理),Spring Cloud Gateway环境搭建,路由断言工厂&#xff08…

颜值即正义,献礼就业季,打造多颜色多字体双飞翼布局技术简历模版(Resume)

一年好景君须记,最是橙黄橘绿时。金三银四,秣马厉兵,没有一个好看的简历模板怎么行?无论是网上随便下载还是花钱买,都是一律千篇的老式模版,平平无奇,味同嚼蜡,没错,蜡都…

一文理解Transformer整套流程

【备注】部分图片引至他人博客,详情关注参考链接 【PS】query 、 key & value 的概念其实来源于推荐系统。基本原理是:给定一个 query,计算query 与 key 的相关性,然后根据query 与 key 的相关性去找到最合适的 value。举个例…

mysql语法大全

首先来一个全局总览,后面我会分别对每个命令进行说明: 如果你的mysql导入环境变量,可以在命令行输入: mysql -u root -p然后输入密码登录数据库 否则,打开mysql command line并输入密码进入数据库 一,基础…

HTTP HTTPS简介

一篇文章带你走进HTTP HTTPS场景复现核心干货HTTP/HTTPS简介(简单比较)HTTP工作原理HTTPS作用场景复现 最近在对前端的深入学习过程中,接触到了与网络请求相关的内容,于是打算出一个专栏,从HTTP与HTTPS入手&#xff0…

针对航空安全风险分析和飞行技术评估问题的题解

文章目录针对航空安全风险分析和飞行技术评估问题的题解思路文章最下方针对航空安全风险分析和飞行技术评估问题的题解 最新进度在文章最下方卡片,加入获取思路数据代码论文:2023十三届MathorCup交流 (第一时间在CSDN分享,文章底部) 思路 问…

VFP读写t5557卡示例源码

T5557卡是美国Atmel公司生产的多功能非接触式射频卡芯片,属于125KHz的低频卡,在国内有广大的应用市场。该芯片共有330bit(比特)的EPROM(分布为10个区块, 每个区块33bit)。0页的块0是被保留用于设置T5557操作模式的参数配置块。第0页第7块可以作用户数据块…

Excel表格怎么换行?4个方法任你选!

案例:excel表格怎么换行 【作为一名excel新手,我真的要被各种功能整懵了!今天又遇到了一个难题!excel表格怎么换行呀?各位大神帮帮我!】 在excel表格中进行换行操作是一种常见的需求,可以使单…

三分天下、格局初定,AR产业千亿市场谁执牛耳?

文|智能相对论 作者| 青月 【这是聚焦智能车与家的“智能相对论”关于创新硬件赛道的第27篇行业分析。】 早在十一年前,谷歌就推出了第一款AR眼镜Google Glass。 可由于当时1500美元的高昂价格,以及并不令人惊艳的体验,这款产品并未俘获消…

Flink1.14 Standalone独立集群模式安装

一、下载 在Flink 官网下载Flink 1.14,完整的安装包名是:flink-1.14.4-bin-scala_2.11.tgz。 二、master 配置 解压安装包,编辑conf/flink-conf.yaml文件: vim conf/flink-conf.yaml jobmanager.rpc.address: 172.21.0.XX tas…

N9010B频谱分析仪

N9010B N9010B EXA 信号分析仪,多点触控,10 Hz 至 44 GHz EXA X系列信号分析仪,多点触摸N9010B 本配置指南将帮助您确定哪些性能选项、测量应用程序、附件和服务将包含在新的多点触摸EXA中,或作为现有EXA的升级添加。主要特性和…

SSM实战-外卖项目-06-用户地址簿功能、菜品展示、购物车、下单

文章目录外卖项目-第六天课程内容1. 用户地址簿功能1.1 需求分析1.2 数据模型1.3 导入功能代码1.4 功能测试 (其实需求分析里我就自己写了一份代码,而且测试过了,下面再测试了一遍)2. 菜品展示2.1 需求分析2.2 前端页面分析2.3 代…

公开下载 | 300+页《服务端开发与面试知识手册》,12.8w字经典架构知识

淘苏(花名)目前是大淘宝技术的一名开发工程师。从国企跳槽来到互联网,【职业规划】是他被问得最多,也思考得最多的问题。回忆国企的三到五年时间,他完成了最初始的技术和经验的积累。接下来的职业生涯规划里&#xff0…

Linux_红帽8学习笔记分享_3

Linux_红帽8学习笔记分享_3 文章目录Linux_红帽8学习笔记分享_31.Vi编辑器1.1两种模式1.2十种技巧2.用户的家目录2.1 su命令的使用2.2 id命令的使用3. 重定向技术3.1查看文件内容的命令3.1.1 cat命令的使用3.1.2 more命令的使用3.2重定向概念3.2输出重定向符3.3标准追加重定向符…

小鹏开启架构造车,冲击年销300万台入场券

作者 | 张祥威 编辑 | 德新2023上海车展开始前,小鹏汽车发布了新一代技术架构SPEA 2.0扶摇。 扶摇是一次重要转向。基于这一新架构,小鹏的整车综合研发成本可以降低50%,接下来将有10多款新车密集投放。 大众进入电动化时代后&#xff0c…

插件化之APK动态加载

插件化相关概念: 根据组件化与插件化的区别来了解一下概念 组件化和插件化的区别 组件化:是将一个APP分成多个模块,每个模块都是一个组件(module),开发的过程中我们可以让这些组件相互依赖或者单独调试部分组件,但是最终发布的…

故障注入测试的作用和应用你了解多少?

故障注入是一种测试技术,用于模拟系统或应用程序中的故障。故障注入测试通常被用来评估系统或应用程序的可靠性和鲁棒性,以便确定系统或应用程序是否能够在各种异常情况下正常运行,那故障注入测试的作用和应用你了解多少? 故障注入…