Netty技术全解析:EventLoopGroup类详解

❃博主首页 : 「码到三十五」 ,同名公众号 :「码到三十五」,wx号 : 「liwu0213」
☠博主专栏 : <mysql高手> <elasticsearch高手> <源码解读> <java核心> <面试攻关>
♝博主的话 : 搬的每块砖,皆为峰峦之基;公众号搜索「码到三十五」关注这个爱发技术干货的coder,一起筑基

Netty作为一个高性能的异步事件驱动的网络应用框架,其核心组件之一便是EventLoopGroupEventLoopGroup在Netty中扮演着线程池的角色,负责管理和调度事件循环,是Netty实现高效并发的基础。本文将结合源码详细介绍Netty中EventLoopGroup类的技术原理和实现细节。

EventLoopGroup的角色与功能

EventLoopGroup在Netty中是一个接口,它本质上是一个线程池,用于获取线程并管理线程的生命周期。每个EventLoopGroup包含一组EventLoop,每个EventLoop都是一个单线程执行器,负责处理分配给它的Channel上的所有IO事件。

主要功能

  1. 事件循环调度EventLoopGroup负责调度事件循环的执行,确保每个事件都在正确的线程上被处理。
  2. 线程管理:通过线程池管理EventLoop的生命周期,可以根据需要创建、启动和销毁线程。
  3. 处理器分配:将IO事件分配给相应的处理器链(ChannelPipeline)进行处理。
  4. 定时任务调度:支持定时任务的调度和执行,如链路空闲状态监测、心跳消息发送等。
  5. 优雅关闭:提供了优雅关闭的能力,确保在关闭时等待正在处理的任务完成。

EventLoopGroup的实现原理

EventLoopGroup的默认实现是NioEventLoopGroup,它基于Java NIO的Selector机制实现IO多路复用。下面结合源码分析其实现原理。

初始化过程

当创建NioEventLoopGroup实例时,可以通过构造函数指定线程数量。如果不指定,则默认创建CPU核心数*2个线程。

public NioEventLoopGroup(int nThreads) {this(nThreads, (Executor) null, SelectorProvider.provider());
}// 省略部分代码...protected MultithreadEventLoopGroup(int nThreads, Executor executor, Object... args) {super(nThreads == 0 ? DEFAULT_EVENT_LOOP_THREADS : nThreads, executor, args);
}// DEFAULT_EVENT_LOOP_THREADS 是静态常量,默认为CPU核心数*2
private static final int DEFAULT_EVENT_LOOP_THREADS;
static {DEFAULT_EVENT_LOOP_THREADS = Math.max(1, SystemPropertyUtil.getInt("io.netty.eventLoopThreads", NettyRuntime.availableProcessors() * 2));
}

线程池的实现

NioEventLoopGroup底层使用Netty自定义的ThreadPerTaskExecutor线程池实现。每个线程都绑定一个EventLoop实例,线程和EventLoop一一对应。

// 在MultithreadEventExecutorGroup中初始化线程
for (int i = 0; i < nThreads; i++) {eventExecutors.add(newThread(new DefaultEventExecutor.DefaultRunnableDecorator(r), namePrefix + "-" + i));
}// DefaultEventExecutor.DefaultRunnableDecorator 封装了Runnable任务
private final class DefaultRunnableDecorator implements Runnable {private final Runnable task;DefaultRunnableDecorator(Runnable task) {this.task = task;}@Overridepublic void run() {// 获取当前线程的EventLoop并执行任务if (eventExecutor.inEventLoop()) {task.run();} else {eventExecutor.execute(task);}}
}

事件处理流程

  1. 注册Channel:当一个新的连接被接受时,Netty会注册一个新的Channel到EventLoopGroup中,并从中选择一个EventLoop绑定到这个Channel上。
  2. 事件循环EventLoop不断地轮询其注册的Channel上的IO事件,一旦有事件就绪,就调用相应的处理器(如ChannelPipeline中的Handler)进行处理。
  3. 任务执行:除了IO事件外,用户还可以提交异步任务到EventLoop执行。这些任务会在IO事件处理完毕后按顺序执行。

优雅关闭

当需要关闭EventLoopGroup时,可以调用shutdownGracefully()方法。该方法会等待正在处理的任务完成后再关闭线程池,确保资源的正确释放。

public final Future<?> shutdownGracefully() {// 省略部分代码...// 提交关闭任务到全局事件执行器globalEventExecutor.execute(() -> {if (confirmShutdown()) {// 遍历并关闭所有EventExecutorfor (EventExecutor e: children) {e.shutdownGracefully();confirmShutdown();}terminationFuture.setSuccess(null);}});return terminationFuture;
}

总结

EventLoopGroup作为Netty框架中的核心组件之一,通过高效的线程管理和事件调度机制,确保了Netty能够快速响应各种网络事件,保持网络通信的流畅和高效。通过对其实现原理的深入理解,我们可以更好地利用Netty框架开发高性能的网络应用。


关注公众号[码到三十五]获取更多技术干货 !

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/873789.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java学校--Object类方法--toString

第一点解析&#xff1a; 全类名就是包名加类名 getClass&#xff08;&#xff09;.getName()是得到其包名和类名如图&#xff0c;包名是com.hspedu.object_类名是Monster。 Integer.toHexString&#xff08;hashCode&#xff08;&#xff09;&#xff09;&#xff1b;是得到其…

Spring中@PostConstruct注解的使用

1.描述 1.1 背景 最近在做一个系统交互日志模块&#xff0c;要监控一个http请求&#xff0c;并记录请求与响应日志。项目中使用RestTemplate来发送http请求&#xff0c;所以打算给RestTemplate设置拦截器&#xff0c;来进行自定义操作。但是&#xff0c;只对当前类生效&#x…

Java文件IO操作知识点

关于文件 关于IO的定义 I:input输入 O:output输出,这是一套人为规定的规则,下面这个图方便我们理解输入输出的定义,统一以CPU为基准 在操作系统中其实把很多的资源都抽象成文件,我们在这里所说的文件就是"狭义"文件,平时保存在硬盘上的文件, 文件夹也是一种文件,我们…

「iOS」自定义cell与cell的复用

iOS学习 前言一&#xff1a;TableView协议二&#xff1a;cell的复用Cell的复用原理自定义cell总结 前言 UITableView是iOS开发中不可或缺的一部分&#xff0c;它是苹果iOS SDK提供的一种用于展示数据列表的视图控件。我们对其中的cell进行自定义&#xff0c;即可得到我们需要的…

Python 实现股票指标计算——BBI

BBI (Bull And Bear lndex) - 多空指标 1 公式 3日均价 3日收盘价之和 / 36日均价 6日收盘价之和 / 612日均价 12日收盘价之和 / 1224日均价 24日收盘价之和 / 24BBI (3日均价 6日均价 12日均价 24日均价) / 4 2 数据准备 我们以科创50指数 000688 为例&#xff0c…

Qt 学习第一天:安装VS和Qt

本人更换了一台新的电脑&#xff0c;使用联想电脑管家传输文件后没有安装VS&#xff0c;导致出现了以下问题&#xff1a; 疯狂查资料问人。弄了一个晚上加上午一个多小时之后&#xff0c;还是决定删掉原来的文件夹&#xff0c;重新下载一个 一、安装VS&#xff08;Visual Stud…

算法项目报告:物流中的最短路径问题

问题描述 物流问题 有一个物流公司需要从起点A到终点B进行货物运输&#xff0c;在运输过程中&#xff0c;该公司需要途径多个不同的城市&#xff0c;并且在每个城市中都有一个配送站点。为了最大程度地降低运输成本和时间&#xff0c;该公司需要确定经过哪些配送站点&#xff…

Android:requestLayout、invalidate 和 postInvalidate 的区别

提醒&#xff1a;下面源码来自SDK里Android-34版本 一、requestLayout 点击查看requestLayout官网文档 1.1 requestLayout方法源码 /*** Call this when something has changed which has invalidated the* layout of this view. This will schedule a layout pass of the v…

C++ :友元类

友元类的概念和使用 (1)将类A声明为B中的friend class后&#xff0c;则A中所有成员函数都成为类B的友元函数了 (2)代码实战&#xff1a;友元类的定义和使用友元类是单向的 (3)友元类是单向的&#xff0c;代码实战验证 互为友元类 (1)2个类可以互为友元类&#xff0c;代码实战…

【LeetCode】二叉树的最大深度

目录 一、题目二、解法完整代码 一、题目 给定一个二叉树 root &#xff0c;返回其最大深度。 二叉树的 最大深度 是指从根节点到最远叶子节点的最长路径上的节点数。 示例 1&#xff1a; 输入&#xff1a;root [3,9,20,null,null,15,7] 输出&#xff1a;3 示例 2&#x…

Leetcode2160. 拆分数位后四位数字的最小和:

问题描述&#xff1a; 给你一个四位 正 整数 num 。请你使用 num 中的 数位 &#xff0c;将 num 拆成两个新的整数 new1 和 new2 。new1 和 new2 中可以有 前导 0 &#xff0c;且 num 中 所有 数位都必须使用。 比方说&#xff0c;给你 num 2932 &#xff0c;你拥有的数位包括…

怎么剪辑音频文件?4款适合新的音频剪辑软件

是谁还不会音频剪辑&#xff1f;无论是个人音乐爱好者&#xff0c;还是专业音频工作者&#xff0c;我们都希望能找到一款操作简便、功能强大且稳定可靠的音频剪辑工具。今天&#xff0c;我就要为大家带来四款热门音频剪辑软件的体验感分享。 一、福昕音频剪辑 福昕音频剪辑是…

YOLO 模型基础入门及官方示例演示

文章目录 Github官网简介模式数据集Python 环境Conda 环境Docker 环境部署 CPU 版本官方 CLI 示例官方 Python 示例 任务目标检测姿势估计图像分类 Ultralytics HUB视频流示例 Github https://github.com/ultralytics/ultralytics 官网 https://docs.ultralytics.com/zhhttp…

【IEEE出版】第四届能源工程与电力系统国际学术会议(EEPS 2024)

第四届能源工程与电力系统国际学术会议&#xff08;EEPS 2024&#xff09; 2024 4th International Conference on Energy Engineering and Power Systems 重要信息 大会官网&#xff1a;www.iceeps.com 大会时间&#xff1a;2024年8月9-11日 大会…

2024年7月萤火虫航天为NASA发射8颗立方体卫星

作为美国宇航局立方体卫星发射计划的一部分&#xff0c;萤火虫航空航天公司于7月3日在该公司的阿尔法火箭上发射了八颗小型卫星。这枚名为“夏日噪音”的火箭于太平洋夏令时&#xff08;PDT&#xff09;晚上9点04分从加利福尼亚州范登堡空军基地的2号航天发射场成功升空。 立方…

解读vue3源码-响应式篇2

提示&#xff1a;看到我 请让我滚去学习 文章目录 vue3源码剖析reactivereactive使用proxy代理一个对象1.首先我们会走isObject(target)判断&#xff0c;我们reactive全家桶仅对对象类型有效&#xff08;对象、数组和 Map、Set 这样的集合类型&#xff09;&#xff0c;而对 str…

【数学建模】多波束测线问题(持续更新)

多波束测线问题 问题 1建立模型覆盖宽度海水深度重叠长度重叠率 问题二问题三问题四 问题 1 与测线方向垂直的平面和海底坡面的交线构成一条与水平面夹角为 α \alpha α的斜线&#xff08;如下图&#xff09;&#xff0c;称 α \alpha α为坡度。请建立多波束测深的覆盖宽度及…

Python代码,强化学习,深度学习

python代码编写&#xff0c;Python算法设计&#xff0c;强化学习优化&#xff0c;改进模型&#xff0c;训练模型&#xff0c;测试模型&#xff0c;可视化绘制&#xff0c;代编运行结果&#xff0c;交互多模型改进&#xff0c;预测模型&#xff0c;算法修改&#xff0c;Python包…

11.斑马纹列表 为没有文本的链接设置样式

斑马纹列表 创建一个背景色交替的条纹列表。 使用 :nth-child(odd) 或 :nth-child(even) 伪类选择器,根据元素在一组兄弟元素中的位置,对匹配的元素应用不同的 background-color。 💡 提示:你可以用它对其他 HTML 元素应用不同的样式,如 <div>、<tr>、<p&g…

利用PyTorch进行模型量化

利用PyTorch进行模型量化 目录 利用PyTorch进行模型量化 一、模型量化概述 1.为什么需要模型量化&#xff1f; 2.模型量化的挑战 二、使用PyTorch进行模型量化 1.PyTorch的量化优势 2.准备工作 3.选择要量化的模型 4.量化前的准备工作 三、PyTorch的量化工具包 1.介…