博客
关于我
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/

你可能感兴趣的文章
PAT甲级——1006 Sign In and Sign Out (25分)
查看>>
PAT甲级——1007 Maximum Subsequence Sum (25分)
查看>>
PAT甲级——1009 Product of Polynomials (25分)(最后一个测试点段错误)
查看>>
PayPal网站付款标准版(for PHP)
查看>>
Paystack Android SDK 集成与使用指南
查看>>
pbf格式详解,javascript加载导出pbf文件示例
查看>>
PbootCMS entrance.php SQL注入漏洞复现
查看>>
PbootCMS 前台RCE漏洞复现
查看>>
PBT
查看>>
PCA---主成成分分析
查看>>
PCA降维demo
查看>>
SharePoint 2013 图文开发系列之定义站点模板
查看>>
PCI Express学习篇:Power Management(二)
查看>>
pcie握手机制_【博文连载】PCIe扫盲——Ack/Nak 机制详解(一)
查看>>
PC史上最悲剧的16次失败
查看>>
PC端恶意代码分析Lab1.1-5.1,从零基础到精通,收藏这篇就够了!
查看>>
PC端编辑 但能在PC端模拟移动端预览的富文本编辑器
查看>>
PDB文件:每个开发人员都必须知道的
查看>>
springMVC学习(二)
查看>>
PDF中的Pandoc语法突出显示不起作用
查看>>