【Netty系列】核心概念

目录

1. EventLoop 与线程模型

2. Channel(通道)

3. ChannelHandler 与 Pipeline

4. ByteBuf(数据容器)

5. Bootstrap 与 ServerBootstrap

6. Future 与 Promise

7. 其他核心概念

总结


Netty 是一个高性能、异步事件驱动的网络框架,其核心设计思想基于 Reactor 模式责任链模式。以下是 Netty 框架的核心概念及其作用:


1. EventLoop 与线程模型

  • EventLoop
    是 Netty 的核心调度单元,负责处理 I/O 事件(如读/写)、用户任务(如 Runnable)和定时任务。
    • 每个 EventLoop 绑定一个线程,避免线程竞争。
    • 一个 EventLoop 可以管理多个 Channel(通过轮询)。
  • 线程模型
    • 单线程模型:所有事件和任务由单个 EventLoop 处理(仅适用于简单场景)。
    • 多线程模型:一个 EventLoopGroup 包含多个 EventLoop,每个 EventLoop 独立处理事件(默认推荐)。
    • 主从多线程模型:主 EventLoopGroup 处理连接,子 EventLoopGroup 处理 I/O(常用于服务端)。

2. Channel(通道)

  • 概念
    Channel 是对网络连接(如 TCP/UDP)的抽象,类似于 Java NIO 的 SocketChannel,但功能更强大。
  • 核心方法
channel.read();      // 读取数据
channel.write();     // 写入数据
channel.connect();   // 建立连接
  • 实现类
    • NioSocketChannel:基于 NIO 的客户端 TCP 通道。
    • NioServerSocketChannel:基于 NIO 的服务端监听通道。
    • 其他传输:如 EpollChannel(Linux 原生)、LocalChannel(本地传输)。

3. ChannelHandler 与 Pipeline

  • ChannelHandler
    处理 I/O 事件或拦截操作的核心组件,需实现以下接口之一:
    • ChannelInboundHandler:处理入站事件(如数据到达、连接建立)。
    • ChannelOutboundHandler:处理出站事件(如数据写出、连接关闭)。
  • Pipeline(责任链)
    将多个 ChannelHandler 串联成链,数据按顺序流动。
pipeline.addLast("decoder", new StringDecoder()); // 解码器
pipeline.addLast("encoder", new StringEncoder()); // 编码器
pipeline.addLast("handler", new CustomHandler()); // 业务逻辑
  • 常用 Handler
    • ByteToMessageDecoder:字节流解码为对象。
    • MessageToByteEncoder:对象编码为字节流。
    • LoggingHandler:日志记录。

4. ByteBuf(数据容器)

  • 特点
    • 替代 Java NIO 的 ByteBuffer,提供更灵活的内存管理。
    • 支持 池化(减少 GC)、引用计数(自动释放)、读写索引分离
  • 操作示例
ByteBuf buf = Unpooled.buffer(1024);
buf.writeInt(100);       // 写入数据
int value = buf.readInt(); // 读取数据
buf.release();           // 手动释放(若未池化)

5. Bootstrap 与 ServerBootstrap

  • 作用
    用于配置客户端和服务端的启动参数。
  • 客户端(Bootstrap)
Bootstrap bootstrap = new Bootstrap();
bootstrap.group(eventLoopGroup).channel(NioSocketChannel.class).handler(new ChannelInitializer<SocketChannel>() {@Overrideprotected void initChannel(SocketChannel ch) {ch.pipeline().addLast(new ClientHandler());}});
  • 服务端(ServerBootstrap)
ServerBootstrap serverBootstrap = new ServerBootstrap();
serverBootstrap.group(bossGroup, workerGroup).channel(NioServerSocketChannel.class).childHandler(new ChannelInitializer<SocketChannel>() {@Overrideprotected void initChannel(SocketChannel ch) {ch.pipeline().addLast(new ServerHandler());}});

6. Future 与 Promise

  • ChannelFuture
    表示异步 I/O 操作的结果,可通过 addListener() 监听完成事件:
ChannelFuture future = channel.write(msg);
future.addListener((ChannelFutureListener) f -> {if (f.isSuccess()) {System.out.println("Write success");} else {f.cause().printStackTrace();}
});
  • Promise
    可手动设置结果的 Future,用于自定义异步逻辑。

7. 其他核心概念

  • 编解码器(Codec)
    ProtobufEncoder/DecoderHttpServerCodec,用于协议解析。
  • 心跳机制
    通过 IdleStateHandler 检测空闲连接。
  • SSL/TLS 支持
    使用 SslHandler 实现加密通信。
  • 零拷贝(Zero-Copy)
    通过 FileRegion 直接传输文件,减少内存复制。

总结

Netty 的核心设计目标是 高吞吐、低延迟、易扩展,通过事件驱动模型和高效的线程管理实现高性能。理解这些核心概念后,可以基于 Netty 轻松构建 TCP/UDP 服务器、HTTP 服务、RPC 框架等复杂网络应用。

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

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

相关文章

C# Costura.Fody 排除多个指定dll

按照网上的说在 FodyWeavers.xml 里修改 然后需要注意的是 指定多个排除项 不是加 | 是换行 一个换行 就排除一项 我测试的 <?xml version"1.0" encoding"utf-8"?> <Weavers xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance&quo…

C++基础算法————广度优先搜索(BFS)

一、引言 在计算机科学中,搜索算法是解决各种问题的关键工具之一。广度优先搜索(Breadth-First Search,简称BFS)作为其中一种重要的搜索算法,以其独特的搜索策略和广泛的应用场景,在众多领域发挥着重要作用。对于初学者来说,深入理解和掌握BFS算法是提升编程能力、解决…

关于Web安全:7. WebShell 管理与持久化后门

一、菜刀马 菜刀马&#xff08;ChinaZ WebShell&#xff09; 是一种与“中国菜刀&#xff08;ChinaZ&#xff09;”客户端配合使用的 WebShell 木马&#xff0c;广泛应用于 Web 渗透测试中&#xff0c;主要使用 PHP/ASP/JSP 等语言编写。 它的本质是一个一句话木马&#xff0…

【仿生系统】qwen的仿生机器人解决方案

收到完整需求后&#xff0c;我将从系统架构设计、算法实现路径、训练方法三个维度为您构建完整的仿生机器人解决方案。以下是分阶段实施方案&#xff1a; 一、核心系统架构设计&#xff08;模块化可进化架构&#xff09; 1. 多模态感知引擎 - 视觉子系统&#xff1a;YOLOv8SAM…

Tomcat- AJP协议文件读取/命令执行漏洞(幽灵猫复现)详细步骤

一、漏洞描述 Apache Tomcat是由Apache软件基金会属下Jakarta项目开发的Servlet容器.默认情况下,Apache Tomcat会开启AJP连接器,方便与其他Web服务器通过AJP协议进行交互.但Apache Tomcat在AJP协议的实现上存在漏洞,导致攻击者可以通过发送恶意的AJP请求,可以读取或者包含Web应…

IEEE P370:用于高达 50 GHz 互连的夹具设计和数据质量公制标准

大多数高频仪器&#xff0c;如矢量网络分析仪 &#xff08;VNA&#xff09; 和时域反射仪 &#xff08;TDR&#xff09;&#xff0c;都可以在同轴接口的末端进行非常好的测量。然而&#xff0c;复杂系统中使用的互连很少具有同轴接口。用于表征这些设备的夹具的设计和实施会对测…

OneForAll 使用手册

OneForAll 使用手册 一、概述 OneForAll 是一款功能强大的子域名收集工具&#xff0c;旨在帮助安全测试人员和网络管理员全面发现目标域名的所有子域名&#xff0c;为后续的安全评估和漏洞测试提供基础支持。它集成了多种子域名发现方法&#xff0c;包括搜索引擎查询、DNS 枚…

从前端工程化角度解析 Vite 打包策略:为何选择 Rollup 而非 esbuild。

文章目录 前言一、esbuild 与 Rollup 的技术特性对比&#xff08;一&#xff09;esbuild&#xff1a;极速开发利器&#xff0c;功能尚待完善&#xff08;二&#xff09;Rollup&#xff1a;专业打包工具&#xff0c;功能全面强大 二、Vite 打包策略的工程化考量因素&#xff08;…

Chrome 通过FTP,HTTP 调用 Everything 浏览和搜索本地文件系统

【提问1】 Chrome调用本地 everything.exe, everything 好像有本地 FTP 服务器&#xff1f; 【DeepSeek R1 回答】 是的&#xff0c;Everything 确实内置了 HTTP/FTP 服务器功能&#xff0c;这提供了一种相对安全的浏览器与本地应用交互的方式。以下是完整的实现方案&#x…

Java八股文智能体——Agent提示词(Prompt)

这个智能体能够为正在学习Java八股文的同学提供切实帮助&#xff1a;不仅可以帮你优化答案表述&#xff0c;还能直接解答八股文相关问题——它会以面试者的视角&#xff0c;给出贴合求职场景的专业回答。 将以下内容发送给任何一个LLM&#xff0c;他会按照你提示词的内容&…

Android 缓存应用冻结器(Cached Apps Freezer)

一、核心功能与原理 1. 功能概述 目标&#xff1a;通过冻结后台缓存应用的进程&#xff0c;减少其对 CPU、内存等系统资源的消耗&#xff0c;优化设备性能与续航。适用场景&#xff1a;针对行为不当的后台应用&#xff08;如后台偷偷运行代码、占用 CPU&#xff09;&#xff…

内存管理 : 06 内存换出

内存换出的重要性及与换入的关系 现在我们讲第25讲&#xff0c;主题是内存的换出&#xff08;swipe out&#xff09;。实际上&#xff0c;上一讲我们讲的是内存的换入&#xff0c;而这一节聚焦于内存的换出。 换入和换出必须合在一起工作&#xff0c;不能只有换入而没有换出。…

第一节 51单片机概述

目录 一、单片机系统组成 &#xff08;一&#xff09;、单片机硬件系统 &#xff08;二&#xff09;单片机的软件系统 二、STC89C52单片机 &#xff08;1&#xff09;、基本信息 &#xff08;2&#xff09;、命名规则 &#xff08;3&#xff09;、单片机内部结构图 &am…

前端面试准备-4

1.React Router的history模式中&#xff0c;push和replace有什么区别 都是用于页面导航&#xff0c;但是他们对浏览器历史记录的处理不一样。 ①&#xff1a;push是在浏览历史栈里加入一条新的浏览历史&#xff0c;点击返回键会返回上一个页面 ②;replace是替换当前历史记录…

【机器学习基础】机器学习入门核心:Jaccard相似度 (Jaccard Index) 和 Pearson相似度 (Pearson Correlation)

机器学习入门核心&#xff1a;Jaccard相似度 &#xff08;Jaccard Index&#xff09; 和 Pearson相似度 &#xff08;Pearson Correlation&#xff09; 一、算法逻辑Jaccard相似度 (Jaccard Index)**Pearson相似度 (Pearson Correlation)** 二、算法原理与数学推导1. Jaccard相…

Unity3D仿星露谷物语开发57之保存库存信息到文件

1、目标 保存下面库存栏中信息到文件中。 2、修改SceneSave.cs脚本 添加2行代码&#xff1a; 3、修改InventoryManager对象 添加Generate GUID组件。 4、修改InventoryManager.cs脚本 添加继承自ISaveable 添加属性信息&#xff1a; private string _iSaveableUniqueID;pub…

测量3D翼片的距离与角度

1&#xff0c;目的。 测量3D翼片的距离与角度。说明&#xff1a; 标注A 红色框选的区域即为翼片&#xff0c;本示例的3D 对象共有3个翼片待测。L1与L2的距离、L1与L2的角度即为所求的翼片距离与角度。 2&#xff0c;原理。 使用线结构光模型&#xff08;标定模式&#xff0…

深入理解 SQL 的 JOIN 查询:从基础到高级的第一步

在处理数据库时&#xff0c;我们常常需要从多个表中提取数据。比如想知道一个城市的天气情况&#xff0c;同时又想知道这个城市的具体位置。这就需要将 weather 表和 cities 表结合起来查询。这种操作在 SQL 中被称为 JOIN 查询。 现在看下两种表的情况 1.weather 表&#xff…

上传头像upload的简易方法,转base64调接口的

1.首页使用el-image显示数据&#xff0c;用的是转base64后端返给的 <el-table-column prop"avatar" align"center" label"头像"><template #default"scope"><el-image style"height: 40px;width: 40px;" :sr…

[AD] CrownJewel-1 Logon 4799+vss-ShadowCopy+NTDS.dit/SYSTEM+$MFT

QA QA攻擊者可以濫用 vssadmin 實用程式來建立卷影快照&#xff0c;然後提取 NTDS.dit 等敏感檔案來繞過安全機制。確定卷影複製服務進入運作狀態的時間。2024-05-14 03:42:16建立卷影快照時&#xff0c;磁碟區複製服務會使用機器帳戶驗證權限並列舉使用者群組。找到卷影複製過…