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…

2024 暑假友谊赛 2

2024 暑假友谊赛 2 2024.7.20 9:00————12:00 过题数3/9 补题数4/9 CodeForces 1150B CodeForces 1332D CodeForces 1503B AtCoder arc134_b AtCoder abc278_d AtCoder abc216_f CodeForces 1012B CodeForces 1328E AtCoder abc344_f A - Tiling Challenge 题解&#xff…

前端监听浏览器关闭事件

在 beforeunload 事件中&#xff0c;无法直接监听离开按钮的点击事件&#xff0c;也不能为 event.currentTarget 添加 close 事件监听器来获取离开按钮的相关事件。 beforeunload 事件主要用于在页面即将卸载&#xff08;刷新或关闭&#xff09;时进行一些必要的处理&#xff0…

Java文件IO操作知识点

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

mysql的数据往hive进行上报时怎么保证数据的准确性和一致性

在将MySQL的数据往Hive进行上报时&#xff0c;确保数据的准确性和一致性可以通过下面一系列步骤来实现 一、准备工作 环境配置&#xff1a; 确保MySQL和Hive环境已经安装并配置好&#xff0c;且都处于可运行状态。检查Hadoop集群&#xff08;Hive通常运行在Hadoop之上&#x…

「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…

肿瘤病人的护理

一、肿瘤病人的心理护理 肿瘤患者往往面临巨大的心理压力和恐惧&#xff0c;心理护理至关重要。 倾听与理解 耐心倾听患者的倾诉&#xff0c;让他们表达内心的担忧、恐惧和不安。例如&#xff0c;一位肺癌患者可能会担心治疗效果和家庭经济负担&#xff0c;护理人员要给予充分的…

Aurora MySQL 负载突增应对策略与优化方案

在面对 Aurora MySQL 负载突增的情况下,我们需要深入理解其工作原理,并探讨可行的优化方案。本文将详细分析 Aurora MySQL 的负载均衡机制,解读性能监控指标,并提出几种可能的解决方案,包括已实施的措施和未来的优化方向。 1. Aurora MySQL 的负载均衡机制 Aurora MySQL…

简单工厂模式、工厂模式和抽象工厂模式的区别

简单工厂模式、工厂模式和抽象工厂模式都是创建型设计模式&#xff0c;它们之间在目的、实现方式和适用场景上存在显著的区别。以下是对这三种模式的详细比较&#xff1a; 一、定义与目的 简单工厂模式&#xff08;Simple Factory Pattern&#xff09; 定义&#xff1a; 简单工…

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

问题描述 物流问题 有一个物流公司需要从起点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…

Java:RestTemplate返回值报错LinkedHashMap cannot be cast

问题描述 使用SringBoot提供的RestTemplate发起http请求&#xff0c;类型转换成了LinkedHashMap DataEntity result restTemplate.getForObject(url, DataEntity.class);报错信息如下 java.lang.ClassCastException: java.util.LinkedHashMap cannot be cast to com.demo.…

跟着GPT学设计模式之模板模式

你好&#xff0c;这里是codetrend专栏“跟着GPT学设计模式”。 说明 提示词: 对模板模式进行定义说明&#xff0c;优缺点说明。 模板模式&#xff0c;全称是模板方法设计模式&#xff0c;英文是 Template Method Design Pattern。模板模式是一种行为型设计模式&#xff0c;它定…

watch监听vue2与vue3的写法

watch的属性值 handler:回调函数, 即监听到变化时应该执行的函数&#xff0c;可以是单独的函数或带有 immediate 和 deep 属性的对象watch: {someProperty: function(newVal, oldVal) {// 处理逻辑}}deep: 其值是true或false, 当属性值是对象或数组时&#xff0c;深度观察会监…

C++ :友元类

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

DP讨论——组合模式

学而时习之&#xff0c;温故而知新。 组合模式 和代理模式相比 和代理模式相比&#xff0c;有点类似。引用类和被引用类都继承于同一个接口类。 但是感觉组合模式是对代理模式的更加丰富化&#xff08;升级版、超进化&#xff09;&#xff0c;集合化或者说聚合化。 组合模…

高并发小结

高并发是指系统能够处理大量的并发请求的能力。处理高并发问题需要从多个层面进行优化&#xff0c;包括架构设计、代码优化、数据库优化和运维管理等。以下是一些处理高并发的关键技术和方法&#xff1a; 1. 架构设计 分布式架构&#xff1a;将系统功能分解为多个独立的服务&…