Netty学习记录
目录
1 Netty简介
Netty是要一个高性能、高可扩展性的异步事件驱动的网络应用程序框架,它极大地简化了TCP和UDP客户端和服务器开发等网络编程。
Netty重要的四个内容:
- Reactor线程模型:一种高性能的多线程程序设计思路
- Netty中自己定义的Channel概念:增强版的通道概念
- ChannelPipeline职责链设计模式:事件处理机制
- 内存管理:增强的ByteBuf缓冲区
Netty整体结构图:
2 Netty线程模型
为了让NIO处理更好的利用多线程特性,Netty实现了reactor线程模型。
Reactor模型中有四个核心概念:
- Resources资源(请求/任务)
- Synchronous Event Demultiplexer同步事件复用器
- Dispatcher分配器
- Request Handler请求处理器
Netty线程模型图:
3 责任链模式
责任链模式为请求创建了一个处理对象的链。
发起请求和具体处理请求的过程进行解耦:职责链上的处理者负责处理请求,客户只需要将请求发送到职责链上即可,无需关系请求的处理细节和请求的传递。
Netty中的ChannelPipeline责任链:
4 Netty的零拷贝机制
Netty的零拷贝机制,是一种应用层的实现。和底层JVM、操作系统内存机制并无过多关联。
- CompositeByteBuf方法:将多个ByteBuf合并为一个逻辑上的ByteBuf,避免了各个ByteBuf之间的拷贝。
- WrapedBuffer方法:将byte[]数组包装成ByteBuf对象。
- slice方法:将一个ByteBuf对象切分成多个ByteBuf对象。