Netty学习记录

目录

1 Netty简介

2 Netty线程模型

3 责任链模式

4 Netty的零拷贝机制


1 Netty简介

Netty是要一个高性能、高可扩展性的异步事件驱动的网络应用程序框架,它极大地简化了TCP和UDP客户端和服务器开发等网络编程。

Netty重要的四个内容:

  • Reactor线程模型:一种高性能的多线程程序设计思路
  • Netty中自己定义的Channel概念:增强版的通道概念
  • ChannelPipeline职责链设计模式:事件处理机制
  • 内存管理:增强的ByteBuf缓冲区

Netty整体结构图:

Netty学习记录

2 Netty线程模型

为了让NIO处理更好的利用多线程特性,Netty实现了reactor线程模型。

Reactor模型中有四个核心概念:

  • Resources资源(请求/任务)
  • Synchronous Event Demultiplexer同步事件复用器
  • Dispatcher分配器
  • Request Handler请求处理器

Netty线程模型图:

Netty学习记录

3 责任链模式

责任链模式为请求创建了一个处理对象的链。

发起请求和具体处理请求的过程进行解耦:职责链上的处理者负责处理请求,客户只需要将请求发送到职责链上即可,无需关系请求的处理细节和请求的传递。

Netty中的ChannelPipeline责任链:

Netty学习记录

4 Netty的零拷贝机制

Netty的零拷贝机制,是一种应用层的实现。和底层JVM、操作系统内存机制并无过多关联。

  • CompositeByteBuf方法:将多个ByteBuf合并为一个逻辑上的ByteBuf,避免了各个ByteBuf之间的拷贝。
  • WrapedBuffer方法:将byte[]数组包装成ByteBuf对象。
  • slice方法:将一个ByteBuf对象切分成多个ByteBuf对象。