Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >NettyIO框架的深度技术解析与实战

NettyIO框架的深度技术解析与实战

原创
作者头像
小马哥学JAVA
发布于 2024-10-22 10:19:21
发布于 2024-10-22 10:19:21
12800
代码可运行
举报
运行总次数:0
代码可运行

背景

Netty是一个异步事件驱动的网络应用程序框架,由JBOSS提供,现已成为Github上的独立项目。Netty旨在帮助开发者快速开发可维护的高性能协议服务器和客户端。它封装了Java NIO的复杂API,解决了原生NIO编程中的诸多问题,如Selector、ServerSocketChannel、SocketChannel、ByteBuffer等的使用复杂性,以及多线程编程和网络编程的额外技能需求。Netty通过提供统一的API、灵活且可扩展的事件模型、高度可定制的线程模型等,极大地简化了网络应用的开发过程。

应用场景

Netty广泛应用于各种需要高性能、高可靠性的网络IO程序的开发中。以下是一些典型的应用场景:

  1. 互联网行业:在分布式系统中,各个节点之间需要远程服务调用,高性能的RPC框架必不可少。Netty作为异步高性能的通信框架,常被用作这些RPC框架的基础通信组件。
  2. 游戏行业:无论是手游服务端还是大型的网络游戏,Netty都提供了TCP/UDP和HTTP协议栈,方便定制和开发私有协议栈,实现账号登录服务器、地图服务器之间的高性能通信。
  3. 大数据领域Hadoop的高性能通信和序列化组件Avro的RPC框架默认采用Netty进行跨节点通信。

功能点

Netty提供了以下主要功能点:

  1. 异步和事件驱动:Netty采用异步和事件驱动的方式处理网络IO,避免了传统阻塞IO模型带来的性能瓶颈。
  2. 零拷贝:Netty通过零拷贝技术减少了不必要的内存拷贝,提高了数据传输效率。
  3. 灵活的线程模型:Netty提供了高度可定制的线程模型,包括单线程模型、多线程模型和主从Reactor多线程模型等,可以根据实际需求进行选择。
  4. 丰富的编解码器:Netty提供了丰富的编解码器,支持多种主流协议,方便进行数据的序列化和反序列化。
  5. 强大的扩展性:Netty的API设计简单直观,易于扩展,开发者可以根据需要添加自定义协议、编解码器等。

底层原理

Netty的底层原理主要基于Java NIO,并对其进行了封装和优化。Netty通过以下机制实现了高性能的网络通信:

  1. I/O复用模型:Netty使用Selector实现I/O复用,允许一个线程同时监控多个通道的事件,降低了线程开销。
  2. 非阻塞IO:Netty采用非阻塞IO模型,线程在没有数据可读或可写时不会阻塞,而是可以执行其他任务,提高了线程的利用率。
  3. 事件驱动:Netty基于事件驱动模型处理网络IO事件,当有事件发生时,会触发相应的处理器进行处理。
  4. Reactor模式:Netty采用Reactor模式实现高并发处理,通过将I/O操作和业务处理分离,提高了系统的并发处理能力。

实战Demo

以下是一个使用Netty实现的简单Echo服务器和客户端的Java代码示例:

服务端代码

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
java复制代码
import io.netty.bootstrap.ServerBootstrap;  
import io.netty.channel.ChannelFuture;  
import io.netty.channel.ChannelInitializer;  
import io.netty.channel.ChannelPipeline;  
import io.netty.channel.EventLoopGroup;  
import io.netty.channel.nio.NioEventLoopGroup;  
import io.netty.channel.socket.SocketChannel;  
import io.netty.channel.socket.nio.NioServerSocketChannel;  
import io.netty.handler.codec.string.StringDecoder;  
import io.netty.handler.codec.string.StringEncoder;  
import io.netty.handler.logging.LogLevel;  
import io.netty.handler.logging.LoggingHandler;  
public class NettyEchoServer {  
private final int port;  
public NettyEchoServer(int port) {  
this.port = port;  
    }  
public void start() throws Exception {  
EventLoopGroup bossGroup = new NioEventLoopGroup(1);  
EventLoopGroup workerGroup = new NioEventLoopGroup();  
try {  
ServerBootstrap b = new ServerBootstrap();  
            b.group(bossGroup, workerGroup)  
             .channel(NioServerSocketChannel.class)  
             .handler(new LoggingHandler(LogLevel.INFO))  
             .childHandler(new ChannelInitializer<SocketChannel>() {  
@Override
public void initChannel(SocketChannel ch) throws Exception {  
ChannelPipeline p = ch.pipeline();  
                     p.addLast(new StringDecoder());  
                     p.addLast(new StringEncoder());  
                     p.addLast(new EchoServerHandler());  
                 }  
             });  
ChannelFuture f = b.bind(port).sync();  
            f.channel().closeFuture().sync();  
        } finally {  
            bossGroup.shutdownGracefully();  
            workerGroup.shutdownGracefully();  
        }  
    }  
public static void main(String[] args) throws Exception {  
int port = 8080;  
new NettyEchoServer(port).start();  
    }  
}  
class EchoServerHandler extends io.netty.channel.ChannelInboundHandlerAdapter {  
@Override
public void channelRead(io.netty.channel.ChannelHandlerContext ctx, Object msg) throws Exception {  
        System.out.println("Server received: " + msg);  
        ctx.write(msg);  
    }  
@Override
public void channelReadComplete(io.netty.channel.ChannelHandlerContext ctx) throws Exception {  
        ctx.flush();  
    }  
@Override
public void exceptionCaught(io.netty.channel.ChannelHandlerContext ctx, Throwable cause) throws Exception {  
        cause.printStackTrace();  
        ctx.close();  
    }  
}

客户端代码

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
java复制代码
import io.netty.bootstrap.Bootstrap;  
import io.netty.channel.ChannelFuture;  
import io.netty.channel.ChannelInitializer;  
import io.netty.channel.ChannelPipeline;  
import io.netty.channel.EventLoopGroup;  
import io.netty.channel.nio.NioEventLoopGroup;  
import io.netty.channel.socket.SocketChannel;  
import io.netty.channel.socket.nio.NioSocketChannel;  
import io.netty.handler.codec.string.StringDecoder;  
import io.netty.handler.codec.string.StringEncoder;  
import io.netty.handler.logging.LogLevel;  
import io.netty.handler.logging.LoggingHandler;  
public class NettyEchoClient {  
private final String host;  
private final int port;  
public NettyEchoClient(String host, int port) {  
this.host = host;  
this.port = port;  
    }  
public void start() throws Exception {  
EventLoopGroup group = new NioEventLoopGroup();  
try {  
Bootstrap b = new Bootstrap();  
            b.group(group)  
             .channel(NioSocketChannel.class)  
             .handler(new ChannelInitializer<SocketChannel>() {  
@Override
public void initChannel(SocketChannel ch) throws Exception {  
ChannelPipeline p = ch.pipeline();  
                     p.addLast(new StringDecoder());  
                     p.addLast(new StringEncoder());  
                     p.addLast(new EchoClientHandler());  
                 }  
             });  
ChannelFuture f = b.connect(host, port).sync();  
            f.channel().closeFuture().sync();  
        } finally {  
            group.shutdownGracefully();  
        }  
    }  
public static void main(String[] args) throws Exception {  
String host = "127.0.0.1";  
int port = 8080;  
new NettyEchoClient(host, port).start();  
    }  
}  
class EchoClientHandler extends io.netty.channel.ChannelInboundHandlerAdapter {  
@Override
public void channelActive(io.netty.channel.ChannelHandlerContext ctx) throws Exception {  
        ctx.writeAndFlush("Hello Netty!");  
    }  
@Override
public void channelRead(io.netty.channel.ChannelHandlerContext ctx, Object msg) throws Exception {  
        System.out.println("Client received: " + msg);  
    }  
@Override
public void exceptionCaught(io.netty.channel.ChannelHandlerContext ctx, Throwable cause) throws Exception {  
        cause.printStackTrace();  
        ctx.close();  
    }  
}

运行步骤

  1. 先运行服务端代码,启动NettyEchoServer。
  2. 再运行客户端代码,启动NettyEchoClient。
  3. 客户端将发送"Hello Netty!"消息到服务端,服务端接收到消息后将其回显给客户端,客户端接收到回显消息后打印出来。

总结

Netty是一个功能强大、性能优异的网络应用程序框架,通过封装和优化Java NIO,提供了简洁易用的API和丰富的功能组件,极大地简化了高性能网络应用的开发过程。本文深入解析了Netty的背景、应用场景、功能点和底层原理,并通过一个实战Demo展示了如何使用Netty实现简单的Echo服务器和客户端。希望这些内容能为资深的架构师们提供一些有价值的参考和启示。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Spring Boot 与 Netty 的概念与实战
Spring Boot: Spring Boot 是一个基于 Spring 框架的开发框架,旨在简化 Spring 应用的开发。它提供了一系列的默认配置和开发工具,帮助开发者快速构建和部署 Spring 应用。
小马哥学JAVA
2024/07/03
3480
nio与netty编程(二)
Netty 是由 JBOSS 提供的一个 Java 开源框架。Netty 提供异步的、基于事件驱动的网络应用程序框架,用以快速开发高性能、高可靠性的网络 IO 程序。 Netty 是一个基于 NIO 的网络编程框架,使用 Netty 可以帮助你快速、简单的开发出一个网络应用,相当于简化和流程化了 NIO 的开发过程。 作为当前最流行的 NIO 框架,Netty 在互联网领域、大数据分布式计算领域、游戏行业、通信行业等获得了广泛的应用,知名的 Elasticsearch 、Dubbo 框架内部都采用了 Netty。
周杰伦本人
2022/10/25
5110
nio与netty编程(二)
java架构之路-(netty专题)netty的基本使用和netty聊天室
  上次博客,我们主要说了我们的IO模型,BIO同步阻塞,NIO同步非阻塞,AIO基于NIO二次封装的异步非阻塞,最重要的就是我们的NIO,脑海中应该有NIO的模型图。
小菜的不能再菜
2020/02/23
1.3K0
2025春招,Netty面试题汇总
>大家好,我是 V 哥。2025年春招Java 面试,肯定绕不开 Netty 的相关问题,V哥替大家跟几位大厂技术主管交流后,整理的一些 2025 年可能会遇到的 Netty 面试题,涵盖基础概念、核心组件、性能优化、故障排查等方面,分享给大家,收藏起来备用。
威哥爱编程
2025/02/05
2120
史诗级最强教科书式“NIO与Netty编程”
java.nio全称java non-blocking IO,是指JDK1.4开始提供的新API。从JDK1.4开始,Java提供了一系列改进的输入/输出的新特性,也被称为NIO(既New IO),新增了许多用于处理输入输出的类,这些类都被放在java.nio包及子包下,并且对原java.io包中的很多类进行改写,新增类满足NIO的功能。 NIO和BIO有着相同的目的和作用,但是它们的实现方式完全不同,BIO以流的方式处理数据,而NIO以块的方式处理数据,块I/O的效率比流I/O高很多。另外,NIO是非阻塞式的,这一点跟BIO也很不相同,使用它可以提供非阻塞式的高伸缩性网络。 NIO主要有三大核心部分 :Channel(通道),Buffer(缓冲区),Selector(选择器)。传统的BIO基于字节流和字符流进行操作,而NIO基于Channel和Buffer(缓冲区)进行操作,数据总是从通道读取到缓冲区中,或者从缓冲区写入到通道中。Selector(选择区)用于监听多个通道的事件(比如 :连接打开,数据到达)。因此使用单个线程就可以监听多个数据管道。
海仔
2019/08/26
9590
史诗级最强教科书式“NIO与Netty编程”
简单实现通过netty通信,后续提供基于protobuf传输协议的rpc框架
后续也会提供service-mesh简单的代码实现 netty通信和socket通信大致是类似的,在socket的基础上对其进行封装,当然你也可以实现netty功能,但是我给你一句话。 packa
gfu
2019/09/29
6410
简单实现通过netty通信,后续提供基于protobuf传输协议的rpc框架
Netty(三)之数据之粘包拆包
客户端发送10个长度的字符串,因为设置了长度为5的定长解码器,所以服务器收到2条消息
CBeann
2023/12/25
2050
Netty(三)之数据之粘包拆包
Netty | 工作流程 & 核心组件讲解 & 代码案例
我们先来看看Netty的工作原理图,简单说一下工作流程,然后通过这张图来一一分析Netty的核心组件。
宁在春
2022/10/31
4.5K1
Netty | 工作流程 & 核心组件讲解 & 代码案例
netty学习
server启动 parentGroup 可以简单的理解一个为一个线程池 NioEventLoop可以理解为一个线程,它本身不是一个线程,但是会绑定一个线程 NioEventLoop对指定的port进行连接监听
用户8447427
2022/08/18
3600
netty学习
Netty 实现简单的RPC远程调用 原
RPC又称远程过程调用,我们所知的远程调用分为两种,现在在服务间通信的方式也太多已这两种为主
chinotan
2019/04/03
2K0
Netty 实现简单的RPC远程调用
                                                                            原
Netty之二进制文件传输
传输会话简要 客户端发起一个文本请求给服务器端, 服务器端解析里面文本, 返回文件给客户端, 客户端解析文件 服务器端 因为示例文件比较小, 所以没有做分段传输, 而是直接一次性把整个文件byte[]
用户1216491
2018/01/24
2.5K0
[自己做个游戏服务器二] 游戏服务器的基石-Netty全解析
Netty的大名我想做java 的基本都知道,因为他实在太出名了,现在很多著名的软件都是使用netty作为通讯基础,今天就聊聊Netty,希望能讲清楚,如果懒得看理论,可以直接拉到后面看Hello world。把代码抄下来,运行一下看看。
香菜聊游戏
2021/10/19
1.9K0
[自己做个游戏服务器二] 游戏服务器的基石-Netty全解析
netty通信框架(socket通信详解)
  题外话,很多人都把JDK1.4提供的NIO称之为异步非阻塞I/O;其实,并不然,从严格意义上面讲,它只能称为非阻塞I/O。在JDK1.7提供的NIO 2.0,新增了异步的套接字通道Channel,它才是真正的异步非阻塞I/O。下表是不同I/O模型的对比:
全栈程序员站长
2022/08/01
2.2K0
netty 构建server和client 服务
编程学习的方法,我认为是以小见大,在理解一个东西之前一定要先会用,并用熟它,这样理解才会快。 就跟理解自行车一样,不会骑,然后先开始研究,最终可能会研究明白,但是毕竟还是事倍功半。 所以先构建一个可以使自己理解的项目,再一点一点学习原理是一种比较好的方式。
潇洒
2023/10/20
2650
Netty Review - 借助SimpleTalkRoom初体验异步网络编程的魅力
小小工匠
2023/12/21
1580
Netty Review - 借助SimpleTalkRoom初体验异步网络编程的魅力
Netty(七)之聊天室小小小案例
客户端与服务端建立连接后会触发 serverHandler中的 channelActive 方法,把channel保存到ChannelGroup中,当客户端给服务端发送消息时,把channelGroup中的每一个channel都把消息发送一遍,就实现群发功能
CBeann
2023/12/25
1840
14-Netty 应用实例 - 多人群聊系统
Netty应用实例 - 群聊系统 需求 编写一个Netty群聊系统, 实现服务器端和客户端之间的数据简单通讯(非阻塞) 实现多人群聊 服务器端: 可以监测用户上下, 离线, 并实现消息转发功能 客户端: 通过channel可以无阻塞发送消息给其他所有用户同时可以接收其他用户发送的消息(由服务器转发得到) 目的: 进一步理解Netty 非阻塞网络编程机制 看老师代码演示 NettyServer package com.dance.netty.netty.groupchar; import io.nett
彼岸舞
2022/02/18
5440
14-Netty 应用实例 - 多人群聊系统
面试官:说说Netty的核心组件?
Netty 核心组件是指 Netty 在执行过程中所涉及到的重要概念,这些核心组件共同组成了 Netty 框架,使 Netty 框架能够正常的运行。
磊哥
2024/05/30
6980
Netty教程系列(一)——netty入门应答程序
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
逝兮诚
2019/10/30
6890
Netty教程系列(一)——netty入门应答程序
Netty入门HelloWorld
今天下班之后无聊,学习了一下长链接的一款非常秀的框架——netty,netty在很多?️java开发的中间件中都有很坚实的地位。于是,在下班之余我学习了一下这款优秀的框架。 从开始搭建到运行 需要准备
简单的程序员
2020/04/20
5750
Netty入门HelloWorld
相关推荐
Spring Boot 与 Netty 的概念与实战
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验