当前位置: 首页 > news >正文

springmvc处理http请求的底层逻辑

http-nio-8088-Poller线程中在org.apache.tomcat.util.net.NioEndpoint.Poller#run这个函数里循环检测selector,若发现有SocketEvent.OPEN_READ事件则会将SelectionKey.attachment中的内容作为入参包装成runable,然后由org.apache.tomcat.util.threads.ThreadPoolExecutor执行任务。

这个runable的实现类是NioEndpoint$SocketProcessor,其中包含了catalina.Request coyote.Request等很多重要对象,还包含了很多HeapByteBuffer用于缓存http请求的字节流数据。详细层级结构如下

NioEndpoint$SocketProcessorthis$0:NioEndpointhandler:AbstractProtocal$ConnectionHandlerrecycledProcessors:AbstractProtocol$RecycledProcessors//缓存Http11Processor- Http11ProcessorinputBuffer:Http11InputBufferbyteBuffer:HeapByteBuffer//org.apache.catalina.connector.InputBuffer#setByteBuffer中会将此处数据复制一份到下文的bb:HeapByteBuffer中request:coyotenotes:Object[]- RequestinputStream:CoyoteInputStreamib:InputBufferbb:HeapByteBuffer//UTF8StreamJsonParser从此拿数据applicationRequest:RequestFacadesocketWrapper:NioEndpoint$NioSocketWrapperevent:SocketEvent

线程池中的线程名类似为http-nio-8088-exec-2。在这个线程中会将从SelectionKey.attachment中获取字节流数据然后放到NioEndpoint$SocketProcessor的HeapByteBuffer中。然后后续的解析器依照HeapByteBuffer将字节流数据解析成对象。

在整个处理流程中,很少创建新对象,基本都是将从SelectionKey.attachment中获取到的数据内容更新到NioEndpoint#SocketProcessor已有的那些对象中。所以调试的时候,在很多对象的构造函数中加断点时断点都没法生效。因为这些对象早就已经构造好了。

为了提高资源使用率,每个runable的HeapByteBuffer中的byte数组其实都是同一个。

为了提高资源使用率,每个runable的org.apache.coyote.Request org.apache.catalina.connector.Request其实都是同一个(在org.apache.catalina.connector.CoyoteAdapter#service加断点可以看到这俩对象是同一个)。

http://www.lryc.cn/news/412005.html

相关文章:

  • 干货满满,从零到一:编程小白如何在大学成为编程大神?
  • 前端-如何通过docker打包Vue服务成镜像并在本地运行(本地可以通过http://localhost:8080/访问前端服务)
  • 零基础学习【Mybatis】这一篇就够了
  • Shell入门(保姆级教学)
  • 【JDK11和JDK8并行与切换】
  • vue大数据量列表渲染性能优化:虚拟滚动原理
  • 昇思25天学习打卡营第1天|快速入门
  • LinkedList 实现 LRU 缓存
  • ubuntu安装workon
  • (面试必看!)锁策略
  • RAGflow:开源AI框架的创新与应用
  • AI的学习明确路径
  • 【C++】巧用缺省参数与函数重载:提升编程效率的秘密武器
  • mysql排查死锁的几个查询sql
  • 快速部署私有化大模型 毕昇(使用docker-compose方式)
  • B端:导航条就框架提供的默认样式吗?非也,看过来。
  • idea的git与SVN切换
  • 互联网家政小程序,为大众带来高效、便捷的服务
  • 【常用库】【pytorch】基本部件
  • 深入Scrapy框架:掌握其工作流程
  • 从零开始学习机器学习,掌握AI未来的关键!
  • CI/CD(持续集成/持续部署)
  • 实现字母的大小写转换。多组输入输出(c语言)
  • 2024华为OD机试真题-最小矩阵宽度Python-C卷D卷-200分
  • 【Vue3】标签的 ref 属性
  • llama-factory 系列教程 (六),linux shell 脚本自动实现批量大模型的训练、部署与评估
  • python安全脚本编写之流量泛洪
  • 一文看懂Java反射、注解、UML图和Lambda表达式
  • 【漏洞复现】搜狗输入法简单绕过Windows锁屏机制
  • JAVA Spring学习Day1