博客
关于我
Tomcat 7 中 NIO 处理分析
阅读量:105 次
发布时间:2019-02-25

本文共 1771 字,大约阅读时间需要 5 分钟。

Tomcat 的 Connector 有三种运行模式:bio、nio、apr。每种模式在性能和特性上都有所不同,选择合适的模式对服务器性能有着重要影响。本文将深入分析 Tomcat 中 NIO 处理方式的相关代码逻辑。

1. NioEndpoint 类核心组件的初始化

NioEndpoint 类是 Tomcat NIO 模式下的核心组件,负责接收和处理网络连接。其初始化过程包括以下几个关键步骤:

  • 线程池的创建:NioEndpoint 类会检查是否存在 Executor 线程池。如果不存在,则会创建一个线程池来处理后续的 Socket 请求。
  • 初始化连接锁:确保启动时的配置正确无误。
  • 启动 Acceptor 线程:Acceptor 线程负责监听 TCP/IP 连接,并将其传递给后续处理。

Acceptor 线程的启动是整个 NIO 处理流程的起点,它负责接收新的 socket 连接,并将其注册到 Poller 中。

2. 请求接收

Acceptor 线程在运行时会持续监听新的 socket 连接。一旦接收到连接请求,它会创建一个新的 SocketChannel 并将其传递给 Poller 进行进一步处理。Poller 负责将接收到的 socket 注册到其事件队列中,以便后续处理。

3. Socket 参数设置

在 Acceptor 线程接收到 socket 之后,会调用 setSocketOptions 方法设置 socket 的相关参数。这一步包括:

  • 设置非阻塞模式:确保 socket 处理采用 NIO 的非阻塞模式。
  • 配置缓冲区:根据 server.xml 中的配置设置读写缓冲区大小。
  • 创建 NioChannel 实例:将 socket 包装成 NioChannel 对象,以便后续处理。

注册完成后,socket 会被添加到 Poller 的事件队列中,等待处理。

4. 读取事件注册

Poller 负责监听 socket 的读写事件。一旦检测到事件(如可读或可写),会将事件对象 PollerEvent 添加到其事件队列中。事件对象包含 socket 的相关信息和处理逻辑。

5. Poller 处理流程

Poller 是 NIO 模式下的多路复用器(Selector),负责轮询就绪的 socket 连接。一旦检测到事件,它会将事件传递给相应的处理器。

  • 事件处理:Poller 会循环检查 selector 是否有就绪的 socket。若有,则创建 PollerEvent 并将其加入事件队列。
  • 事件传递:PollerEvent 会被执行,处理 socket 的读写操作。

6. 将 socket 交给 Worker 执行

在 Poller 处理完成后,socket 会被交给 Worker 进行具体处理。Worker 会根据请求类型调用相应的处理器(如 HttpServletRequest),生成响应并发送给客户端。

7. 从 socket 中处理请求

SocketProcessor 是 Worker 的核心类,负责从 socket 中读取数据并调用处理器。其处理流程包括:

  • 读取事件:获取 socket 的 SelectionKey,判断是否有数据可读或可写。
  • 执行处理器:根据事件类型调用相应的处理器(如 RequestHandler),生成响应。
  • 关闭连接:在处理完成后,关闭 socket 并释放资源。

8. 关键代码分析

NIO 处理流程的核心代码分布在以下类中:

  • NioEndpoint:负责监听和初始化相关组件。
  • Poller:负责轮询和事件处理。
  • SocketProcessor:负责具体的 socket 数据处理。

这些类通过 ThreadPoolExecutor、ConcurrentLinkedQueue 和 Selector 等高级抽象化组件,实现了高效的网络通信和资源管理。

9. 总结

Tomcat 的 NIO 处理流程通过 Poller 和 Worker 模型,实现了高效的网络通信。Acceptor 负责接收连接,Poller 负责事件轮询,SocketProcessor 负责数据处理。这种架构使得 Tomcat 在高并发场景下的性能表现显著优于传统的 BIO 模式。

转载地址:http://vtn.baihongyu.com/

你可能感兴趣的文章
Open××× for Linux搭建之二
查看>>
Open×××有线网络时使用正常,无线网络时使用报错的解决方案
查看>>
Operation not supported on read-only collection 的解决方法 - [Windows Phone开发技巧系列1]
查看>>
Operations Manager 2007 R2系列之仪表板(多)视图
查看>>
operator new 与 operator delete
查看>>
operator() error
查看>>
OPPO K3在哪里打开USB调试模式的完美方法
查看>>
Optional类:避免NullPointerException
查看>>
ORA-00932: inconsistent datatypes: expected - got NCLOB【ORA-00932: 数据类型不一致: 应为 -, 但却获得 NCLOB 】【解决办法】
查看>>
ORA-00942 表或视图不存在
查看>>
ORA-01795: 列表中的最大表达式数为 1000
查看>>
ORA-06575: 程序包或函数 NO_VM_DROP_PROC 处于无效状态
查看>>
ORA-08102的错误
查看>>
ora-12541:tns:no listener
查看>>
【docker知识】联合文件系统(unionFS)原理
查看>>
ORACEL学习--理解over()函数
查看>>
oracle 10g crs命令,Oracle 10g CRS安装问题解决一例
查看>>
oracle 10g的安装配置
查看>>
Oracle 11.2.0.4 x64 RAC修改public/private/vip/scan地址
查看>>
Oracle 11G INDEX FULL SCAN 和 INDEX FAST FULL SCAN 对比分析
查看>>