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

【Netty系列】Reactor 模式 2

目录

流程图说明

关键流程


以下是 Reactor 模式流程图,结合 Netty 的主从多线程模型,帮助你直观理解事件驱动和线程分工:


流程图说明

  1. Clients(客户端)
    • 多个客户端(Client 1~N)向服务端发起连接请求。
  1. Main Reactor(主 Reactor)
    • bossGroup 中的单个 EventLoop 线程负责监听端口(如 8080)。
    • Acceptor 接受新连接,并将新连接的 Channel 分配给 workerGroup 中的某个子 Reactor(如轮询分配)。
  1. Sub Reactors(子 Reactor)
    • workerGroup 包含多个 EventLoop 线程(如 EventLoop 1~N),每个线程处理多个 Channel 的 I/O 事件。
    • 例如:EventLoop 1 处理 Channel 1 的读写,EventLoop 2 处理 Channel 2 的读写。
  1. ChannelPipeline(责任链)
    • 每个 Channel 对应一个 Pipeline,数据按顺序经过解码器、业务逻辑、编码器等处理步骤。

关键流程

  1. 连接建立
    • 客户端发起 TCP 连接 → Main Reactor 的 Acceptor 接受连接 → 分配 Channel 给 Sub Reactor。
  1. I/O 事件处理
    • Sub Reactor 的 EventLoop 监听 Channel 的读写事件 → 触发 channelRead → 数据通过 Pipeline 处理。
  1. 非阻塞机制
    • 每个 EventLoop 使用 Selector 监听多个 Channel,实现单线程处理多连接的 I/O 事件。

相关文章:

  • CSS 渐变完全指南:从基础概念到实战案例(线性渐变/径向渐变/重复渐变)
  • Golang持续集成与自动化测试和部署
  • Xamarin劝退之踩坑笔记
  • Google car key:安全、便捷的汽车解锁新选择
  • iOS 集成网易云信的音视频呼叫组件
  • 负载均衡群集---Haproxy
  • 历年南京理工大学计算机保研上机真题
  • JavaScript中的命名导出(暴露)
  • 事件驱动架构入门
  • PHP学习笔记(十一)
  • pikachu通关教程-CSRF XSS
  • 工厂方法模式(Factory Method)深度解析:从原理到实战优化
  • 智能教育个性化学习路径规划系统实战指南
  • mongodb集群之分片集群
  • vscode中让文件夹一直保持展开不折叠
  • 1. pytorch手写数字预测
  • 数据结构与算法之Josephu(约瑟夫环问题)
  • 预处理深入详解:预定义符号、宏、命名约定、命令行定义、条件编译、头文件的包含
  • JavaScript 性能优化实战研讨
  • 吴恩达MCP课程(1):chat_bot
  • 六安论坛招聘网最新招聘/北京seo招聘
  • 做a免费网站/谈谈你对网络营销的认识
  • 人力管理系统/搜索引擎优化工作
  • 申请域名之后如何做网站/地推的60种方法
  • wordpress做教育网站/百度一下手机版首页
  • 郑州网站开发培训价格/工具站seo