一起来学习Netty的组件(Channel、EventLoop与ChannelFuture)

159 阅读2分钟

这是我参与8月更文挑战的第19天,活动详情查看:8月更文挑战

本文将介绍以下内容:

1、Netty的技术和体系结构方面的内容
2、Channel、EventLoop和ChannelFuture

一、Netty的技术和体系结构方面的内容

  从高层次的角度来看,Netty解决了两个相应的关注领域,我们可将其大致标记为技术的和体系结构的。首先,它的基于Java NIO的异步的和事件驱动的实现,保证了高负载下应用程序 性能的最大化和可伸缩性。其次,Netty也包含了一组设计模式,将应用程序逻辑从网络层解耦,简化了开发过程,同时也最大限度地提高了可测试性、模块化以及代码的可重用性。

二、Channel、EventLoop和ChannelFuture

Netty网络的抽象的代表:

  • Channel——socket
  • EventLoop——控制流、多线程处理、并发
  • ChannelFuture——异步通知

2.1 Channel接口

  基本的I/O操作(bind()、connect()、read()和write()依赖于底层网络传输所提供的原语。在基于Java的网络编程中,其基本的构造是class Socket。Netty的Channel接口所提供的API,大大地降低了直接使用Socket类的复杂性。此外,Channel也是拥有许多预定义的、专门化实现的广泛类层次结构的根,下面是部分清单:

  • EmbeddedChannel;
  • LocalServerChannel;
  • NioDatagramChannel;
  • NioSctpChannel;
  • NioSocketChannel.

2.2 EventLoop接口

  EventLoop定义了Netty的核心抽象,用于处理连接的生命周期中所发生的事件。目前下图在高层次说明了Channel、EventLoop、Thread以及EventLoopGroup之间的关系。

image.png 这些关系分别是:

  • 一个EventLoopGroup包含一个或者多个EventLoop;
  • 一个EventLoop在它的生命周期内只和一个Thread绑定;
  • 所有由EventLoop处理的I/O事件都将在它专有的Thread上被处理;
  • 一个Channel在它的生命周期内只注册于一个EventLoop;
  • 一个EventLoop可以会被分配给一个或多个Channel。   注意,在这种设计中,一个给定Channel的I/O操作都是由相同的Thread执行的,实际上消除了对于同步的需要。

2.3 ChannelFuture接口

  Netty中所有的I/O操作都是异步的,因为一个操作可能不会立即返回,所以我们需要一种用于在之后的某个时间点确定其结果的方法。为此,Netty提供了ChannelFuture接口,其addListener()方法注册了一个ChannelFutureListener,以便在某个操作完成时(无论是否成功)得到通知。