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

【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 框架等复杂网络应用。

相关文章:

【Netty系列】核心概念

目录 1. EventLoop 与线程模型 2. Channel&#xff08;通道&#xff09; 3. ChannelHandler 与 Pipeline 4. ByteBuf&#xff08;数据容器&#xff09; 5. Bootstrap 与 ServerBootstrap 6. Future 与 Promise 7. 其他核心概念 总结 Netty 是一个高性能、异步事件驱动的…...

Axure中继器交互完全指南:核心函数解析×场景实战×避坑策略(懂得才能应用)

亲爱的小伙伴,在您浏览之前,烦请关注一下,在此深表感谢!如有帮助请订阅专栏! Axure产品经理精品视频课已登录CSDN可点击学习https://edu.csdn.net/course/detail/40420 主要内容:中继器核心函数解析、场景方法详解、注意事项、特殊函数区别 课程目标:提高中继器的掌握…...

DeepSeek 赋能数字人直播带货:技术革新重塑电商营销新生态

目录 一、引言二、DeepSeek 技术探秘2.1 DeepSeek 技术原理剖析2.2 DeepSeek 与其他大模型对比优势 三、数字人直播带货现状洞察3.1 数字人直播带货发展历程回顾3.2 市场规模与增长趋势分析3.3 现存问题与挑战探讨 四、DeepSeek 在数字人直播带货中的应用实例4.1 交个朋友的成功…...

高端制造行业 VMware 替代案例合集:10+ 头部新能源、汽车、半导体制造商以国产虚拟化支持 MES、PLM 等核心应用系统

在“中国制造 2025”政策的推动下&#xff0c;国内的新能源、汽车制造、半导体、高端装备等高端制造产业迎来了蓬勃发展&#xff0c;成为全球制造业版图中举足轻重的力量。订单数量的激增与国产化转型的趋势&#xff0c;也为高端制造企业的 IT 基础设施带来了新的挑战&#xff…...

【b站计算机拓荒者】【2025】微信小程序开发教程 - chapter3 项目实践 - 3人脸识别采集统计人脸检测语音识别

https://www.bilibili.com/video/BV1WgQdYNERe/?p87&spm_id_from333.788.top_right_bar_window_history.content.click&vd_sourcec919d6976fd77ac77f9860cf2e7e0e11 1 人脸识别 # 1 采集完-人脸图片好上传到百度人脸识别-后期使用百度进行人脸识别-保存、删除等-后期…...

达梦的TEMP_SPACE_LIMIT参数

达梦的TEMP_SPACE_LIMIT参数 TEMP_SPACE_LIMIT是达梦数据库中控制临时表空间使用上限的重要参数&#xff0c;它限制了数据库会话可以使用的临时表空间总大小。 一、参数基本说明 1. 参数作用 限制单个会话可以使用的临时表空间总量防止异常SQL消耗过多临时空间影响系统稳定…...

24核32G,千兆共享:裸金属服务器的技术原理与优势

在云计算和数据中心领域&#xff0c;裸金属服务器正逐渐成为企业追求高性能计算的热门选择。本文将深入探讨裸金属服务器的技术原理&#xff0c;以及以“24核32G&#xff0c;千兆共享”配置为代表的裸金属服务器所具备的独特优势。 一、裸金属服务器的技术原理 &#xff08;一…...

杆塔倾斜在线监测装置:电力设施安全运行的“数字守卫”

在输电线路、通信基站及风电设施等场景中&#xff0c;杆塔作为支撑核心设备的基础结构&#xff0c;其稳定性直接关系到能源传输与信息通信的安全。传统人工巡检方式存在效率低、响应滞后等局限&#xff0c;而杆塔倾斜在线监测装置通过技术赋能&#xff0c;实现了对杆塔状态的实…...

C++23 新成员函数与字符串类型的改动

文章目录 引言std::basic_string::contains 与 std::basic_string_view::contains (P1679R3)功能介绍示例代码优势 禁止从 nullptr 构造 std::basic_string 和 std::basic_string_view (P2166R1)背景改动影响 std::basic_string_view 的显式范围构造函数 (P1989R2)功能介绍示例…...

在 ElementUI 中实现 Table 单元格合并

在 ElementUI 中实现 Table 单元格合并 在使用 ElementUI 的 Table 组件时&#xff0c;有时我们需要合并相邻的单元格&#xff0c;以提高表格的可读性和简洁性。下面是一个关于如何在 Table 中根据特定字段合并单元格的实现方法。 逻辑分析 spanMethod 方法&#xff1a;这是 …...

threejs渲染器和前端UI界面

1. three.js Canvas画布布局 学习本节课之前&#xff0c;可以先回顾下第一章节入门部分的6和12两小节关于threejs Canvas画布布局的讲解。 网页上局部特定尺寸&#xff1a;1.6 第一个3D案例—渲染器(opens new window) 全屏&#xff0c;随窗口变化:1.12 Canvas画布布局和全屏…...

AI笔记 - 网络模型 - mobileNet

网络模型 mobileNet mobileNet V1网络结构深度可分离卷积空间可分![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/aff06377feac40b787cfc882be7c6e5d.png) 参考 mobileNet V1 网络结构 MobileNetV1可以理解为VGG中的标准卷积层换成深度可分离卷积 可分离卷积主要有…...

day12 leetcode-hot100-20(矩阵3)

48. 旋转图像 - 力扣&#xff08;LeetCode&#xff09; 1.辅助数组法&#xff08;题目不让&#xff09; 思路&#xff1a;很简单&#xff0c;新建一个二维数组&#xff0c;直接找新数组与旧数组的规律即可。比如这个旋转90。那就是相当于 new[col][n-row-1]old[row][col],然后…...

【Java开发日记】基于 Spring Cloud 的微服务架构分析

目录 1、Spring Cloud 2、Spring Cloud 的核心组件 1. Eureka&#xff08;注册中心&#xff09; 2. Zuul&#xff08;服务网关&#xff09; 3. Ribbon&#xff08;负载均衡&#xff09; 4. Hystrix&#xff08;熔断保护器&#xff09; 5. Feign&#xff08;REST转换器&a…...

接口性能优化

一、耗时统计 在做接口的性能优化时&#xff0c;最重要的是知道时间消耗在哪里。 可以用StopWatch&#xff0c;进行耗时统计。 详情见&#xff1a; https://blog.csdn.net/sinat_32502451/article/details/148350451 二、链路追踪 如果团队使用了Skywalking&#xff0c;可以…...

AWTK 嵌入式Linux平台实现多点触控缩放旋转以及触点丢点问题解决

前言 最近涉及海图的功能交互&#xff0c;多点触摸又开始找麻烦。 在PC/Web平台awtk是通过底层的sdl2库来实现多点触摸&#xff0c;但是在嵌入式Linux平台&#xff0c;可能是考虑到性能原因&#xff0c;awtk并没有采用sdl库来做事件处理&#xff0c;而是自己实现一个awtk-lin…...

尚硅谷redis7 93-97 springboot整合reids之总体概述

93 springboot整合reids之总体概述 总体概述 jedis-lettuce-RedisTemplate三者的联系 名称类型作用描述和其它的关系JedisRedis 客户端早期主流的 Java Redis 客户端&#xff0c;基于阻塞 I/O&#xff0c;同步操作可作为 RedisTemplate 的底层连接实现LettuceRedis 客户端基…...

Flutter、React Native、Unity 下的 iOS 性能与调试实践:兼容性挑战与应对策略(含 KeyMob 工具经验)

移动端跨平台开发逐渐成为常态&#xff0c;Flutter、React Native、Unity、Hybrid App 等框架在各类 iOS 项目中频繁出现。但随之而来的&#xff0c;是一系列在 iOS 设备上调试难、性能数据采集难、日志整合难的问题。 今天这篇文章&#xff0c;我从实际项目出发&#xff0c;聊…...

声纹技术体系:从理论基础到工程实践的完整技术架构

文章目录 一、声纹技术的理论基础与概念内核1.1 声纹的生物学本质与数学表征1.2 特征提取的理论基础与实现机制 二、声纹识别技术的演进逻辑与方法体系2.1 传统统计学方法的理论架构2.2 深度学习方法的技术革新2.3 损失函数的设计原理与优化策略 三、声纹识别系统的架构设计与模…...

行为型:命令模式

目录 1、核心思想 2、实现方式 2.1 模式结构 2.2 实现案例 3、优缺点分析 4、适用场景 5、实际应用 1、核心思想 目的&#xff1a;将指令信息封装成一个对象&#xff0c;并将此对象作为参数发送给接收方去执行&#xff0c;以使命令的请求方与执行方解耦 概念&#xff…...

构建多模型协同的Ollama智能对话系统

构建多模型协同的Ollama智能对话系统 在人工智能应用中&#xff0c;单一模型往往难以满足复杂场景的需求。本文将介绍如何整合多个Ollama模型&#xff0c;构建一个智能对话系统&#xff0c;实现情感分析、危机评估和智能回复的协同功能。 系统架构 该系统采用多模型pipeline…...

vue3 + WebSocket + Node 搭建前后端分离项目 开箱即用

[TOC](vue3 WebSocket Node 搭建前后端分离项目) 开箱即用 前言 top1&#xff1a;vue3.5搭建前端H5 top2&#xff1a;Node.js koa搭建后端服务接口 top3&#xff1a;WebSocket 长连接实现用户在线聊天 top4&#xff1a;接口实现模块化 Mysql 自定义 top5&#xff1a;文件上…...

Win10秘笈:两种方式修改网卡物理地址(MAC)

Win10秘笈&#xff1a;两种方式修改网卡物理地址&#xff08;MAC&#xff09; 在修改之前&#xff0c;可以先确定一下要修改的网卡MAC地址&#xff0c;查询方法有很多种&#xff0c;比如&#xff1a; 1、在设置→网络和Internet→WLAN/以太网&#xff0c;如下图所示。 2、在控…...

【软件】navicat 官方免费版

Navicat Premium Lite https://www.navicat.com.cn/download/navicat-premium-lite...

【深度学习】16. Deep Generative Models:生成对抗网络(GAN)

Deep Generative Models&#xff1a;生成对抗网络&#xff08;GAN&#xff09; 什么是生成建模&#xff08;Generative Modeling&#xff09; 生成模型的主要目标是从数据中学习其分布&#xff0c;从而具备“生成”数据的能力。两个关键任务&#xff1a; 密度估计&#xff0…...

java操作服务器文件(把解析过的文件迁移到历史文件夹地下)

第一步导出依赖 <dependency><groupId>org.apache.sshd</groupId><artifactId>sshd-core</artifactId><version>2.13.0</version></dependency> 第二步写代码 public void moveFile( List<HmAnalysisFiles> hmAnalys…...

特伦斯 S75 电钢琴:重构演奏美学的极致表达

在数字音乐时代&#xff0c;电钢琴正从功能性乐器升级为融合艺术、科技与生活的美学载体。特伦斯 S75 电钢琴以极简主义哲学重构产品设计&#xff0c;将专业级演奏体验与现代家居美学深度融合&#xff0c;为音乐爱好者打造跨越技术边界的沉浸式艺术空间。 一、极简主义的视觉叙…...

STM32-标准库-GPIO-API函数

1.void GPIO_DeInit(GPIO_TypeDef* GPIOx); 简明 清除GPIOx的外围寄存器下所有引脚的配置, 恢复到默认配置状态&#xff08;即上电初始值&#xff09; 参数 GPIOx&#xff1a;其中x可以是&#xff08;A..G&#xff09;来选择GPIO外设。 返回值 None void GPIO_DeInit(GPI…...

Java 文件操作 和 IO(4)-- Java文件内容操作(2)-- 字符流操作

Java 文件操作 和 IO&#xff08;4&#xff09;-- Java文件内容操作&#xff08;2&#xff09;-- 字符流操作 文章目录 Java 文件操作 和 IO&#xff08;4&#xff09;-- Java文件内容操作&#xff08;2&#xff09;-- 字符流操作观前提醒&#xff1a;1. Java中操作文件的简单介…...

机器学习与深度学习06-决策树02

目录 前文回顾5.决策树中的熵和信息增益6.什么是基尼不纯度7.决策树与回归问题8.随机森林是什么 前文回顾 上一篇文章地址&#xff1a;链接 5.决策树中的熵和信息增益 熵和信息增益是在决策树中用于特征选择的重要概念&#xff0c;它们帮助选择最佳特征进行划分。 熵&#…...