Tomcat原理系列之六:详解socket如何封装成request(上)
@(详解socket如何封装成request)
看源码虽然不能马上提升你的编码水平。但能让你更好的理解编程。
因为我们tomcat多是以NIO形式处理请求,所以本系列讲的都是NIO类型请求的处理相关组件。
在讲解过程之前,把相关概念理解是非常关键的。
参与者
tomcat中Connector是负责处理请求的。
协议处理ProtocolHandler
Connector使用ProtocolHandler处理器来处理请求。不同的ProtocolHandler代表不同连接类型。
ProtocolHandler处理器可以用看作是协议处理统筹者,通过管理其他工作组件实现对请求的处理。ProtocolHandler 包含了三个非常重要的组件:
Endpoint: 负责接受,处理socket网络连接
Processor: 负责将从Endpoint接受的socket连接根据协议类型封装成request
Adapter:负责将封装好的Request交给Container进行处理。
Socket的封装
NioChannel: SocketChannel的基础包装类,在EndPonit中使用。
SocketWrapper:socket的包装类,用于携带(NioChannel)socket进行传递。
区别:NioChannel是基本包装,SocketWrapper是对NioChannel的进一步包装.
多种buffer
- 套接字输入流InputStream:属于jdk中的io包。充当操作系统从底层读取socket字节的通道
- SokcetBuffer即ByteBuffer。位于java.nio包下,NIO层面的buffer。Tomcat在创建此类Buffer时默认的大小时8*1024,也就是8K
- InputBuffer接口(内部缓冲区):coyote包下, 用于Tomcat内部的Request缓冲区。套接字输入缓冲装置,即提供一种缓冲的模式从socket中读取字节流。通过查看源码我感觉他也是一个工具接口,更加偏向于一个工具.列如:实现类Http11InputBuffer,具有提供解析请求头与转义功能.
- InputBuffer类:connector包下。用于Servlet规范的Request内部的缓冲区
- MessageBytes消息字节:tomcat在接受socket传入的字节之后并不会马上进行编码转换,而是保持byte[]数组,在用到的地方再进行转换。MessageBytes正是byte[]的抽象
- 子节块操作工具ByteChunk: 首先他是一个工具,一个操作缓冲的工具。其次有两个内部接口:ByteInputChannel和ByteOutputChannel读写数据。还有一个Chartset对象方便编码。所以他是一个提供了编码功能,操作缓存的工具。
两对request,response
tomcat中存在两组request,respone
- org.apache.coyote包下的:
属于Tomcat内部对请求的一个定义,final类型的类不对开发者开放。主要功能就是封装socket解析http协议的header内容。 - org.apache.catalina.connector包下的:
属于对servlet规范的实现。也是我们开发常见的request对象。
所以tomcat中会有一个涉及request与request的转换过程,这些过程都放到后续讲,此篇只讲解组件概念。
Tomcat内部使用Apache Coyote库来处理网络I/O的。Connector包多是用于Serlvet规范。
多种处理器
tomcat内部很多都命名为处理器。这里讲讲提几个讲讲区别:
- ProtocolHandler处理器:统筹或者管理级别的处理器。Connector把请求处理的工作交给ProtocolHandler去处理。剩下的是ProtocolHandler统筹。由此看出他是一个管理界别的处理器
ConnectionHandler:连接处理器,.内部维护Processor的map用于重用SocketProcessor. 把创建Processor的工作交给ProtocolHandler去做.
SocketProcessor处理器调用ConnectionHandler.process()将socket请求内容传入Processor.process()进行处理.
由此可见ConnectionHandler具有承上启下的作用.
- SocketBufferHandler:socketBuffer处理器。包含两个SocketBuffer,用于socket读写的缓冲。
- SocketProcessor: socket处理器,针对socket的处理器。本身是一个worker,将socket内容交给Processor处理
(Processor)Http11Processor: HTTP协议1.1是目前使用最多的一个HTTP协议版本。从此处理器的名字我们也可以看出,他就是针对此协议的处理。此处理器是将socket转为请求的主要组件,他从socket将HTTP协议的内容解析出来,不过在tomcat中他只负责了对http请求行,请求头的解析;请求体的解析延迟到了servlet中去解析了。 Http11Processor 由ConnectionHandler 创建,tomcat 对关键的类都实现了重用,以减少频繁创建和销毁的开销,会从recycledProcessors 里pop出来
总结
掌握了这些相关组件的概念后。下章讲解socket如何变成request。
Tomcat原理系列之六:详解socket如何封装成request(上)的更多相关文章
- 【tomcat系列】详解tomcat架构(上篇)
java中,常用的web服务器一般由tomcat,weblogic,jetty,undertwo等,但从用户使用广泛度来说,tomcat用户量相对比较大一些,当然这也基于它开源和免费的特点. 从软件架 ...
- Go语言备忘录:反射的原理与使用详解
目录: 预备知识 reflect.Typeof.reflect.ValueOf Value.Type 动态调用 通过反射可以修改原对象 实现类似“泛型”的功能 1.预备知识: Go的变量都是静态类 ...
- Tomcat配置(二):tomcat配置文件server.xml详解和部署简介
*/ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...
- Tomcat(二):tomcat配置文件server.xml详解和部署简介
Tomcat系列文章:http://www.cnblogs.com/f-ck-need-u/p/7576137.html 1. 入门示例:虚拟主机提供web服务 该示例通过设置虚拟主机来提供web服务 ...
- Spring学习 6- Spring MVC (Spring MVC原理及配置详解)
百度的面试官问:Web容器,Servlet容器,SpringMVC容器的区别: 我还写了个文章,说明web容器与servlet容器的联系,参考:servlet单实例多线程模式 这个文章有web容器与s ...
- Go语言备忘录(2):反射的原理与使用详解
本文内容是本人对Go语言的反射原理与使用的备忘录,记录了关键的相关知识点,以供翻查. 文中如有错误的地方请大家指出,以免误导!转摘本文也请注明出处:Go语言备忘录(2):反射的原理与使用详解,多谢! ...
- 反爬虫:利用ASP.NET MVC的Filter和缓存(入坑出坑) C#中缓存的使用 C#操作redis WPF 控件库——可拖动选项卡的TabControl 【Bootstrap系列】详解Bootstrap-table AutoFac event 和delegate的分别 常见的异步方式async 和 await C# Task用法 c#源码的执行过程
反爬虫:利用ASP.NET MVC的Filter和缓存(入坑出坑) 背景介绍: 为了平衡社区成员的贡献和索取,一起帮引入了帮帮币.当用户积分(帮帮点)达到一定数额之后,就会“掉落”一定数量的“帮帮 ...
- <转>详解DNS的常用记录(上):DNS系列之二
详解DNS的常用记录(上) 在上篇博文中,我们介绍了DNS服务器的体系结构,从中我们了解到如果我们希望注册一个域名,那么必须经过顶级域名服务器或其下级的域名服务器为我们申请的域名进行委派,把解析权委派 ...
- Apache + Tomcat集群配置详解 (1)
一.软件准备 Apache 2.2 : http://httpd.apache.org/download.cgi,下载msi安装程序,选择no ssl版本 Tomcat 6.0 : http://to ...
随机推荐
- [转] java开源游戏
收藏一下 triplea Triplea是一个开放源码的boardgame.它允许玩家选择各种各样的战略版图游戏(如:轴心国或同盟军).TripleA引擎支持联网对战,支持声音,支持使用XML文 ...
- rpm包制作介绍
RPM(Rpm Package Management)在ReadHat等发行版下被用作软件包管理程序,其将某个软件相关的文件置入一个.rpm包中,用rpm命令,我们可以方便地完成Linux下软件安装. ...
- 《深入理解Java虚拟机》-(实战)练习修改class文件
这是一篇修改class文件的文章.注释并不完全,要抓住这次练习的目的: boolean在虚拟机中是以何种方式解读的 好的,开始我的表演 1.安装asmtools.jar 2.编写一个java文件,并编 ...
- 免费IP代理池定时维护,封装通用爬虫工具类每次随机更新IP代理池跟UserAgent池,并制作简易流量爬虫
前言 我们之前的爬虫都是模拟成浏览器后直接爬取,并没有动态设置IP代理以及UserAgent标识,本文记录免费IP代理池定时维护,封装通用爬虫工具类每次随机更新IP代理池跟UserAgent池,并制作 ...
- vim 基础配置
最近在使用 python 搞服务, 简单配置了一个 vim, 配置了自动补全以及背景色 .(ps:搜狗输入法快捷键占用真是太坑爹,改用谷歌输入法,世界安静了) 具体配置如下: 一. 安装插件 1.克隆 ...
- 纯数据结构Java实现(0/11)(开篇)
为嘛要写 本来按照我的风格,其实很不喜欢去写这些细节的东西,因为笔记上直接带过了. 本来按照我的风格,如果要写,那也是直接上来就干,根本不解释这些大纲,参考依据. 本来按照我的风格,不想太显山露水,但 ...
- Mina各组件介绍
Mina各组件介绍 上一篇文章已经系统的介绍了Mina的运行流程,Apache推出的Mina性能上很是高效,上章节我们知道内部有很多的类,各个类之间的依赖也是很多,他们之家都是相互依赖. 下面主要看看 ...
- 解决HTML5实现一键拨号、一键发短信及上传头像兼容性问题
HTML5实现一键拨号,一键发短信以及上传头像等问题都是比较常见的场景,近期在做移动端项目的时候遇到阻挠,通过查找资料解决了问题: 废话不多说,直接上案例代码: HTML5实现一键拨号: <a ...
- c11标准
在编译器vs13及其以上可以使用 编译器对语言的一种优化 1.变量初始化 int a=0,a(10),a{10};定义a的值的三种方式 2.nullptr 相当于c的null 有类型 更加的安全 3. ...
- Istio 太复杂?KubeSphere基于Ingress-Nginx实现灰度发布
在 Bookinfo 微服务的灰度发布示例 中,KubeSphere 基于 Istio 对 Bookinfo 微服务示例应用实现了灰度发布.有用户表示自己的项目还没有上 Istio,要如何实现灰度发布 ...