【Netty 网络通信】Netty 工作流程分析

简介: 【1月更文挑战第9天】Netty 工作流程分析

Netty主要基于主从Reactor多线程模型。BossGroup线程维护Selector只关注Accept事件。当接收到Accept事件,获取到对应的SocketChannel,封装成NioSocketChannel并注册到Worker线程(事件循环),并进行维护。当Worker线程监听到Selector中通道发生自己感兴趣的事件后,就进行处理(Handler),注意Handler必须是添加到通道中的。

Netty工作原理:

  1. Netty抽象出两组线程池BossGroup专门负责接收客户端的连接,WorkderGroup专门负责网络的读写。
  2. BossGroupWorkerGroup类型都是NioEventLoopGroup
  3. NioeventLoopGroup相当于一个事件循环组。这个组中含有多个事件循环,每一个事件循环是NioEventLoop
  4. NioEventLoop表示一个不断循环的执行处理任务的线程,,每个NioEventLoop都有一个Selector,用于监听绑定在其上的Socket的网络通讯。
  5. NioEventLoopGroup可以有多个线程,即可以含有多个NioEventLoop
  6. 每个Boss NioEventLoop循环执行的步骤:
  1. 轮询处理Accept事件
  2. 处理Accept事件,与Client建立连接,生成NioSocketChannel,并将其注册到某个Worker NioEventLoop上的Selector
  3. 处理任务队列的任务,即runAllTask
  1. 每个Worker NioEventLoop循环执行的步骤:
  1. 轮询ReeadWrite事件
  2. 处理I/O事件,即ReeadWrite事件,在对应NioSocketChannel处理
  3. 处理任务队列的任务,即RunAllTask
  1. 每个Worker NioEventLoop处理业务时,会使用Pipelien(管道),Pipeline中包含了Channel,即通过Pipeline可以获取到对应的通道,Channel管道中维护了很多的处理器

相关文章
|
2月前
|
机器学习/深度学习 编解码 计算机视觉
【APFN】从大佬论文中探索如何分析改进金字塔网络
【APFN】从大佬论文中探索如何分析改进金字塔网络
34 0
|
2月前
|
机器学习/深度学习 分布式计算 资源调度
【社交网络分析】课程考试复盘 + 相关资料补充
【社交网络分析】课程考试复盘 + 相关资料补充
52 0
|
23天前
|
监控 Shell Linux
【Shell 命令集合 网络通讯 】Linux 分析串口的状态 statserial命令 使用指南
【Shell 命令集合 网络通讯 】Linux 分析串口的状态 statserial命令 使用指南
32 0
|
5天前
|
安全 网络安全 网络虚拟化
虚拟网络设备与网络安全:深入分析与实践应用
在数字化时代📲,网络安全🔒成为了企业和个人防御体系中不可或缺的一部分。随着网络攻击的日益复杂和频繁🔥,传统的物理网络安全措施已经无法满足快速发展的需求。虚拟网络设备🖧,作为网络架构中的重要组成部分,通过提供灵活的配置和强大的隔离能力🛡️,为网络安全提供了新的保障。本文将从多个维度深入分析虚拟网络设备是如何保障网络安全的,以及它们的实际意义和应用场景。
|
16天前
|
缓存 网络协议 数据库连接
【底层服务/编程功底系列】「网络通信体系」深入探索和分析TCP协议的运输连接管理的核心原理和技术要点
【底层服务/编程功底系列】「网络通信体系」深入探索和分析TCP协议的运输连接管理的核心原理和技术要点
9 0
|
存储 设计模式 网络协议
Netty网络框架(一)
Netty网络框架
29 1
|
20天前
|
运维 负载均衡 监控
【软件设计师备考 专题 】网络性能分析
【软件设计师备考 专题 】网络性能分析
39 0
|
2月前
|
JSON 监控 网络安全
使用Perl编写的上网监控管理软件:网络数据包拦截与分析功能
网络安全一直是互联网时代的重要议题之一。随着网络技术的不断发展,网络攻击和数据泄露等问题也变得日益严重。为了有效监控和管理网络流量,开发了一款基于Perl语言的上网监控管理软件,该软件具有强大的网络数据包拦截与分析功能,能够帮助网络管理员实时监控网络流量,并及时发现和应对各种网络安全威胁。
124 0
|
2月前
|
机器学习/深度学习 自然语言处理 算法
社交网络分析(汇总)
社交网络分析(汇总)
104 0
|
2月前
|
存储 前端开发 算法
加密算法在网络通信中的应用及优势分析
本文将探讨加密算法在网络通信中的重要性,以及不同加密算法的应用和优势。通过对前端、后端、Java、Python、C、PHP、Go等多种技术的分析,我们将了解在日益增长的网络威胁下,加密算法对于确保数据安全和隐私保护的必要性。