`

Netty5源码分析--0.核心领域概念

 
阅读更多

Netty是什么

由于通用的协议或者实现有时不能满足各种各样的需求,比如我们通常不会用一个HTTP Server来同时进行传输大文件,email以及近实时的消息如金融信息和多玩家游戏数据。我们需要一个高度优化的协议实现,来满足一些特定的需求。

Netty是一个异步,事件驱动的网络应用框架,并且提供了一些工具来帮助迅速地开发高性能,高扩展性的服务端和客户端。


核心领域概念介绍

隐喻

Channel 公路,双向道,分为去路和来路。隐喻为网络连接。

ChannelPipeline,公路管理部门,可以设置收费站,关卡等设施对车辆进行检查。

ByteBuf 车辆。隐喻为网络连接中的数据。

Handler 收费站,关卡;可以对公路上的车辆进行各种处理。


Channel

顶层接口,因为有不同的通讯协议,比如TCP、UDP、rxtx等等以及不同的通讯模型,如OIO,NIO,AIO;所以针对这些不同的实现来提供一个统一的接口,在必要的时候,进行向下转型(Downcast),方便扩展。

该接口提供如下功能:
当前channel的状态(比如是否open,connected)
当前channel的配置参数(比如receive buffer size)
当前channel支持的操作(比如read, write, connect, and bind)

另外,仍然需要值的一提是,Netty中的所有I/O操作都是异步的。这意味着这些I/O方法被调用时,会立即返回ChannelFuture,并不保证这些I/O操作实际完成(比如将数据已经发送到对端)。ChannelFuture会告诉你这个I/O操作结果是成功,失败还是取消。

Channel有一个parent。比如,SocketChannelServerSocketChannel的"accept方法"的返回值(ServerSocketChannel中并没有accept方法,但是在ServerSocket中是存在的)。所以,SocketChannel的 parent()返回ServerSocketChannel

ChannelPipeline

ChannelPipeline,顾名思义,意为“Channel的流水线”,处理了Channel中所有的I/O事件和请求。ChannelPipeline该类通过了实现Intercepting Filter pattern,结合ChannelHandler接口的实现类,提供了类似将流水线的工作分成多个步骤的功能。每个ChannelHandler接口的实现类完成了一定的功能,并且可以灵活地在流水线上增加,替换,删除Handler,极大地提高了框架的灵活性。

每个Channel在实例化时,会自动创建一个ChannelPipeline实例。

Inbound 通常用来表示从外界读入数据,OutBound通常用来表示将数据写出到外界。在TCP/IP协议栈中,数据需要从操作系统的栈读入,数据写出时也需要经过操作系统的TCP/IP栈。在Netty的实现中,只有一个Handler链,将时间触发,数据发送和数据接收结合在一起。但这个也是有点费解。

在触发Inbound I/O Event时,handler依照从0到N-1顺序被netty框架触发;在触发Outbound I/O Event时,handler依照从N-1到0顺序被netty框架触发。

Inbound event传播的方法 :

  • ChannelHandlerContext.fireChannelRegistered()
  • ChannelHandlerContext.fireChannelActive()
  • ChannelHandlerContext.fireChannelRead(Object)
  • ChannelHandlerContext.fireChannelReadComplete()
  • ChannelHandlerContext.fireExceptionCaught(Throwable)
  • ChannelHandlerContext.fireUserEventTriggered(Object)
  • ChannelHandlerContext.fireChannelWritabilityChanged()
  • ChannelHandlerContext.fireChannelInactive()

Outbound event 传播的方法 :

  • ChannelHandlerContext.bind(SocketAddress, ChannelPromise)
  • ChannelHandlerContext.connect(SocketAddress, SocketAddress, ChannelPromise)
  • ChannelHandlerContext.write(Object, ChannelPromise)
  • ChannelHandlerContext.flush()
  • ChannelHandlerContext.read()
  • ChannelHandlerContext.disconnect(ChannelPromise)
  • ChannelHandlerContext.close(ChannelPromise)

read和write方法都放在Outbound event,这个真让我丈二和尚摸不着头脑哈。

ChannelPipeline是线程安全的,所以ChannelHandler可以在任意时刻被增加,移除和替换。

EventLoopGroup 和 EventLoop

类继承关系如下,JUC.ScheduledExecutorService<–EventExecutorGroup<–EventLoopGroup<–EventLoop。这个”<–“表示是符号的右边继承符号的左边接口,下同。

JUC.ScheduledExecutorService是JUC框架的线程调度框架。

EventExecutorGroup增加了next()children()方法;另外还Deprecated了父接口的shutdown()shutdownNow()方法,新增了isShuttingDown()shutdownGracefully()shutdownGracefully()terminationFuture()

EventLoopGroup 覆写了EventExecutorGroupEventLoop next()方法。

EventLoop在继承了EventLoopGroup的同时,也继承了EventExecutor接口。所以这里补充介绍下EventExecutor类,它继承了EventExecutorGroup,另外,它主要新增了EventExecutorGroup parent()方法和boolean inEventLoop(Thread thread)方法。

EventLoop自身主要新增了 ChannelHandlerInvoker asInvoker()方法,它主要负责处理所有I/O操作。

从职责上讲,EventLoop表示事件循环的意思,也就是死循环来捕获不同的事件,比如说是否可读,可写等等。EventExecutorGroup则表示一组EventLoop,所以它里面才有next()children()方法。另外,这几个类有点乱,尤其是父接口EventExecutorGroup依赖了子接口EventLoop,违反了DIP原则。

Future,ChannelFuture 和 ChannelPromise

ChannelFuture表示实际的I/O操作还未发生。因为在netty中,所有的I/O操作(如read, write, connect,和bind)都是异步的。类继承关系如下,JUC.Future<–Future<–ChannelFuture<–ChannelPromise

Future继承了JUC框架里的Future接口,还主要新增了isSuccess(),isCancellable(),cause()方法;此外还新增了注册Future完成的时候触发对应的Listener的功能

ChannelFuture主要新增了Channel channel()方法。

ChannelPromise在继承ChannelFuture的同时,还继承了Promise接口。该Promise主要增加了对Future的写方法,如 Promise<V> setSuccess(V result)等。也就是说,ChannelPromise基本是ChannelFuturePromise的结合体。

也就是说,ChannelFuture不仅细化了JUC.Future语义,可以方便知道到底是成功,取消还是异常,还提供了Channel channel()ChannelPromise则可以根据程序的运行结果设置一些业务含义。另外,也可以观察到,在子接口里仅仅把父接口方法返回值覆写了,然后什么都不做。这样一定程度上避免了强制转型的尴尬。

ByteBuf

ByteBuf支持随机和顺序访问内部的字节。它具有readerIndex和writerIndex。它们的关系如下:

1 +-------------------+------------------+------------------+
2   | discardable bytes |  readable bytes  |  writable bytes  |
3   |                   |     (CONTENT)    |                  |
4   +-------------------+------------------+------------------+
5   |                   |                  |                  |
6   0      <=      readerIndex   <=   writerIndex    <=    capacity

建议使用 Unpooled等helper方法来创建ByteBuf对象,而不是直接使用ByteBuf的实现的构造器。在5.0版本,建议使用PooledByteBufAllocator来创建ByteBuf对象。

Bootstrap 和 ServerBootstrap

Bootstrap这个词在计算机中,通常表示某个框架开始执行的第一段代码。详见What is bootstrapping?

在Netty中,Bootstrap是客户端启动类,ServerBootstrap是服务端启动类,用来帮助程序员迅速开始工作。


分享到:
评论

相关推荐

    nacos-server-1.1.0-SNAPSHOT.tar.gz

    《深入剖析Nacos Server 1.1.0-SNAPSHOT:源码解析与核心功能探秘》 在当今数字化时代,分布式系统管理成为了IT领域的热门话题。Nacos,作为阿里巴巴开源的一款动态服务发现、配置管理和远程调用中间件,自发布以来...

    netty-netty-4.1.19.Final.zip_netty_netty学习_rocketmq

    然后,通过分析RocketMQ的源码,观察它是如何利用Netty来实现网络通信的。可以尝试自己编写简单的Netty服务器和客户端,模拟RocketMQ的消息发布和消费过程,加深理解。 总的来说,Netty作为强大的网络通信框架,为...

    Netty源码剖析与实战配套代码.zip

    这个"Netty源码剖析与实战配套代码.zip"文件包含了对Netty框架的深入源码分析和实战应用示例。下面将详细探讨Netty的核心概念和关键功能,以及它如何在实际项目中发挥作用。 1. **Netty概述** - Netty是由JBOSS...

    wait-side-car-源码.rar

    本文将深入探讨"wait-side-car"项目的源码,旨在帮助读者解析其内部机制,掌握核心概念和技术细节。 "wait-side-car"项目名称可能来源于赛车术语,暗示该项目可能是作为一个辅助或支持角色存在的,等待为其他系统...

    Netty权威指南-Netty源码

    总的来说,Netty 源码分析涉及了网络编程、并发处理、事件驱动、协议编解码等多个领域,对理解 Java 高性能网络应用开发有着重要的指导意义。通过阅读源码,我们可以更深入地了解 Netty 如何实现高效的网络通信,并...

    rocketmq-all-4.2.0-bin-release.zip

    5. **src** 目录:源代码,虽然通常在部署时我们不需要修改源码,但对于深入理解 RocketMQ 内部机制和进行定制开发的开发者来说,这是一个宝贵的资源。 6. **examples** 目录:包含了一些示例程序,展示了如何使用 ...

    learning-netty.zip

    这个“learning-netty.zip”压缩包包含了一份Netty的学习笔记,重点在于代码学习和源码分析,基于Netty的4.1版本。下面将围绕Netty的核心概念、特性、以及如何通过学习笔记来深入理解Netty进行详细阐述。 1. **...

    高性能网络通信框架Netty从入门到核心源码剖析.rar

    四、Netty源码分析 1. Channel初始化:探讨ServerBootstrap和Bootstrap如何创建并初始化Channel。 2. 事件传播:分析EventLoop如何处理和分发事件,以及Handler如何接收和处理这些事件。 3. ByteBuf实现:研究...

    Netty架构源码剖析_netty_

    深入源码分析,我们可以看到Netty如何优雅地处理了线程安全、内存池管理、心跳机制、解码编码、零拷贝等高级特性。例如,Netty通过内部的DirectBufferPool和HeapBufferPool实现了内存池,减少了内存分配和释放的开销...

    基于Java的实例源码-异步IO框架 Cindy.zip

    5. **Cindy源码分析**:通过阅读和分析Cindy的源码,我们可以深入理解其内部工作原理,包括事件循环的实现、回调机制的调度以及如何优雅地处理并发问题。这对于提升Java并发编程和系统优化的能力非常有价值。 6. **...

    01.Netty源码剖析简介.rar

    在进行Netty源码剖析之前,我们需要了解几个关键概念: 1. **NIO(Non-blocking I/O)**:Java NIO是一种不同于传统的阻塞I/O模型的新I/O方式。在传统的阻塞I/O中,当进行读写操作时,线程会被阻塞,直到操作完成。...

    dubbo源码解析2

    在开始深入解析Dubbo源码之前,首先需要明确的是,Dubbo虽然代码量不算庞大,但是它涉及的技术领域非常广泛,对于初学者来说,可能需要具备一定的前置知识才能更好地理解和学习。以下是建议的学习路径: 1. **Java...

    netty 权威指南2 源码

    《Netty 权威指南2》是一本深入解析Netty框架的专业书籍,其中包含了Netty的核心概念、设计模式以及源码分析。这本书的目标是帮助开发者理解和掌握Netty的内部工作原理,从而更好地利用它来构建高效、可靠的网络应用...

    Netty权威指南第二版源码

    源码分析可以帮助理解这两者之间的交互,以及如何优雅地处理并发和多线程问题。 3. **ByteBuf**:Netty的自定义缓冲区类,提供了高效的数据读写和内存管理。通过源码,可以学习到如何优化数据传输和避免不必要的...

    netty 配套资源-代码、文档

    学习 Netty 的资源通常包括源码分析、官方文档、示例项目以及社区提供的教程。压缩包中的“代码”部分可能包含了 Netty 的示例代码或者已经实现的协议处理器,这对于理解框架的工作原理非常有帮助。而“文档”部分...

    Netty权威指南(含源码)

    这本书详细介绍了Netty的核心概念、设计模式以及实战应用,旨在帮助读者全面掌握这一高性能、异步事件驱动的网络应用程序框架。Netty广泛应用于分布式系统、微服务架构、游戏服务器开发等领域。 在内容上,该书涵盖...

    netty权威指南第二版源码

    - 通过源码分析,解决实际开发中遇到的问题,提高故障排查能力。 此外,书中例子代码可以帮助你更好地理解和实践这些概念,而提供的 jar 包则可以直接用于你的项目,快速构建基于 Netty 的网络服务。 总之,...

    Netty4源码深入剖析(高清视频教程) .rar

    在深入探讨之前,让我们先了解一下Netty的一些基本概念和特性。 Netty 的核心在于其NIO(非阻塞I/O)模型,它基于Java的Selector和Channel API,使得Netty能够高效地处理大量并发连接。NIO允许单个线程处理多个通道...

Global site tag (gtag.js) - Google Analytics