zoukankan      html  css  js  c++  java
  • tomcat9-连接器(1)

    tomcat核心功能

      1.处理socket连接,负责网络字节流与request和response对象的转化

      2.加载管理servlet,以及具体处理Request请求

      根据以上两点,tomcat设计了两个核心组件,连接器(Connector)、容器(container),来分别做这两个事情。连接器负责对外交流,容器负责内部的处理。

    tomcat支持的I/O模型

      NIO:非阻塞 I/O,采用 Java NIO 类库实现。

      NIO.2:异步 I/O,采用 JDK 7 最新的 NIO.2 类库实现。

      APR:采用 Apache 可移植运行库实现,是 C/C++ 编写的本地库

      Tomcat 为了实现支持多种 I/O 模型和应用层协议,一个容器可能对接多个连接器,就好比一个房间有多个门。但是单独的连接器或者容器都不能对外提供服务,需要把它们组装起来才能工作,组装后这个整体叫作 Service 组件。这里请你注意,Service 本身没有做什么重要的事情,只是在连接器和容器外面多包了一层,把它们组装在一起。Tomcat 内可能有多个 Service,这样的设计也是出于灵活性的考虑。通过在 Tomcat 中配置多个 Service,可以实现通过不同的端口号来访问同一台机器上部署的不同应用。

    Tomcat 支持的应用层协议

      HTTP/1.1:这是大部分 Web 应用采用的访问协议。

      AJP:用于和 Web 服务器集成(如 Apache)。

      HTTP/2:HTTP 2.0 大幅度的提升了 Web 性能。

    连接器

      连接器对 Servlet 容器屏蔽了协议及 I/O 模型等的区别,无论是 HTTP 还是 AJP,在容器中获取到的都是一个标准的 ServletRequest 对象。我们可以把连接器的功能需求进一步细化,比如:

    •   监听网络端口。
    •   接受网络连接请求。
    •   读取网络请求字节流。
    •   根据具体应用层协议(HTTP/AJP)解析字节流,生成统一的 Tomcat Request 对象。
    •   将 Tomcat Request 对象转成标准的 ServletRequest。
    •   调用 Servlet 容器,得到 ServletResponse。
    •   将 ServletResponse 转成 Tomcat Response 对象。
    •   将 Tomcat Response 转成网络字节流。将响应字节流写回给浏览器。

      连接器相关类图:

       

       ProtocolHandler 组件

        连接器用 ProtocolHandler 来处理网络连接和应用层协议,包含了 2 个重要部件:Endpoint 和 Processor,下面我来详细介绍它们的工作原理。

        1.Endpoint

          Endpoint 是通信端点,即通信监听的接口,是具体的 Socket 接收和发送处理器,是对传输层的抽象,因此 Endpoint 是用来实现 TCP/IP 协议的。

          Endpoint 是一个接口,对应的抽象实现类是 AbstractEndpoint,而 AbstractEndpoint 的具体子类,比如在 NioEndpoint 和 Nio2Endpoint 中,有两个重要的子组件:Acceptor 和 SocketProcessor。

          其中Acceptor用于监听Socket连接请求,SocketProcessor用于处理接收到的Socket请求,它实现Runnable接口,在run方法里调用协议处理组件Processor进行处理。为了提高处理能力,SocketProcessor被提交到线程池来执行。而这个线程池叫执行器(Excutor)。

        2.Processor

          如果说Endpoint是实现TCP/IP协议的,那么Processor用来实现HTTP协议,Processor接收来自Endpoint的socket,读取字节流解析成Tomcat Request和Response对象,并通过Adapter将其提交到容器处理,Processor是对应用层协议的抽象。

          processor是一个接口,定义了请求的处理等方法。它的抽象实现类AbstractProcessor对一些协议共有的属性进行封装,没有对方法进行实现。具体实现有ApjProcessor、Http11Processor等,这些具体实现类实现了特定协议的解析方法和请求处理方式。

      Endpoint、Processor 和 Adapter关系图:

      

     

       从图中我们看到,Endpoint 接收到 Socket 连接后,生成一个 SocketProcessor 任务提交到线程池去处理,SocketProcessor 的 run 方法会调用 Processor 组件去解析应用层协议,Processor 通过解析生成 Request 对象后,会调用 Adapter 的 Service 方法。 

      Adapter 组件

        由于协议不同,客户端发过来的请求信息也不尽相同,Tomcat 定义了自己的 Request 类来“存放”这些请求信息。ProtocolHandler 接口负责解析请求并生成 Tomcat Request 类。但是这个 Request 对象不是标准的 ServletRequest,也就意味着,不能用 Tomcat Request 作为参数来调用容器。Tomcat 设计者的解决方案是引入 CoyoteAdapter,这是适配器模式的经典运用,连接器调用 CoyoteAdapter 的 sevice 方法,传入的是 Tomcat Request 对象,CoyoteAdapter 负责将 Tomcat Request 转成 ServletRequest,再调用容器的 service 方法。

  • 相关阅读:
    Embedded
    uboot第一阶段详细分析
    nandflash裸机程序分析
    u-boot在nandflash中的前4k内容分析
    使用JLink间接烧写s3c6410 nand_flash的方法
    Emacs
    U-boot 软浮点 错误 解决方法
    linux系统移植流程
    使用JLink烧写bin文件到Mini2440
    uboot-2012.07移植到fl2440开发板(一)
  • 原文地址:https://www.cnblogs.com/aaronzheng/p/12674323.html
Copyright © 2011-2022 走看看