Netty介绍

简介:

Netty是由JBOSS开发的高性能、异步事件驱动的NIO框架,它提供了对TCPUDP和文件传输等协议的支持,作为一个异步NIO框架,Netty的所有IO操作都是异步非阻塞的,通过Future-Listener机制,用户可以方便的主动获取或者通过通知机制获得IO操作结果。作为当前最流行的NIO框架之一,Netty在互联网领域、大数据分布式计算领域、游戏行业、通信行业等获得了广泛的应用,其服务框架如下:

clip_image002[4]

图 1    Netty服务框架

Netty是典型的Reactor模型结构,其中常用的Reactor线程模型有三种,分别为:Reactor单线程模型、Reactor多线程模型和主从Reactor多线程模型。而在Netty的线程模型并非固定不变,通过在启动辅助类中创建不同的EventLoopGroup实例并通过适当的参数配置,就可以支持上述三种Reactor线程模型。

lReactor单线程模型

Reactor单线程模型指的是所有的IO操作都在同一个NIO线程上面完成。作为NIO服务端接收客户端的TCP连接,作为NIO客户端向服务端发起TCP连接,读取通信对端的请求或向通信对端发送消息请求或者应答消息。由于Reactor模式使用的是异步非阻塞IO,所有的IO操作都不会导致阻塞,理论上一个线程可以独立处理所有IO相关的操作。

clip_image004[4]

图 2    Netty Reactor单线程模型

lReactor多线程模型

对于一些小容量应用场景,可以使用单线程模型,但是对于高负载、大并发的应用却不合适,需要对该模型进行改进,演进为Reactor多线程模型。Rector多线程模型与单线程模型最大的区别就是有一组NIO线程处理IO操作。

在该模型中有专门一个NIO线程-Acceptor线程用于监听服务端,接收客户端的TCP连接请求;而1NIO线程可以同时处理N条链路,但是1个链路只对应1NIO线程,防止发生并发操作问题。网络IO操作-读、写等由一个NIO线程池负责,线程池可以采用标准的JDK线程池实现,它包含一个任务队列和N个可用的线程,由这些NIO线程负责消息的读取、解码、编码和发送。

clip_image006[4]

图 3    Netty Reactor多线程模型

l主从Reactor多线程模型

在并发极高的情况单独一个Acceptor线程可能会存在性能不足问题,为了解决性能问题,产生主从Reactor多线程模型。主从Reactor线程模型的特点是:服务端用于接收客户端连接的不再是个1个单独的NIO线程,而是一个独立的NIO线程池。Acceptor接收到客户端TCP连接请求处理完成后(可能包含接入认证等),将新创建的SocketChannel注册到IO线程池(sub reactor线程池)的某个IO线程上,由它负责SocketChannel的读写和编解码工作。Acceptor线程池仅仅只用于客户端的登陆、握手和安全认证,一旦链路建立成功,就将链路注册到后端subReactor线程池的IO线程上,由IO线程负责后续的IO操作。

clip_image008[4]

图 4    Netty主从Reactor多线程模型










本文转自shishanyuan博客园博客,原文链接:http://www.cnblogs.com/shishanyuan/p/6200764.html   ,如需转载请自行联系原作者




相关文章
|
JavaScript 前端开发 Java
Netty In Action中文版 - 第一章:Netty介绍
Netty In Action中文版 - 第一章:Netty介绍 Netty介绍 为什么要使用non-blocking IO(NIO) 阻塞IO(blocking IO)和非阻塞IO(non-blocking IO)对比 Java NIO的问题和在Netty中的解决方案 Netty是基于Java NIO的网络应用框架,如果你是Java网络方面的新手,那么本章将是你学习Java网络应用的开始;对于有经验的开发者来说,学习本章内容也是很好的复习。
2025 0
|
存储 缓存 NoSQL
跟着源码学IM(十一):一套基于Netty的分布式高可用IM详细设计与实现(有源码)
本文将要分享的是如何从零实现一套基于Netty框架的分布式高可用IM系统,它将支持长连接网关管理、单聊、群聊、聊天记录查询、离线消息存储、消息推送、心跳、分布式唯一ID、红包、消息同步等功能,并且还支持集群部署。
13564 1
|
9月前
|
消息中间件 Oracle Dubbo
Netty 源码共读(一)如何阅读JDK下sun包的源码
Netty 源码共读(一)如何阅读JDK下sun包的源码
172 1
|
NoSQL Java Redis
跟着源码学IM(十二):基于Netty打造一款高性能的IM即时通讯程序
关于Netty网络框架的内容,前面已经讲了两个章节,但总归来说难以真正掌握,毕竟只是对其中一个个组件进行讲解,很难让诸位将其串起来形成一条线,所以本章中则会结合实战案例,对Netty进行更深层次的学习与掌握,实战案例也并不难,一个非常朴素的IM聊天程序。 原本打算做个多人斗地主练习程序,但那需要织入过多的业务逻辑,因此一方面会带来不必要的理解难度,让案例更为复杂化,另一方面代码量也会偏多,所以最终依旧选择实现基本的IM聊天程序,既简单,又能加深对Netty的理解。
192 1
|
9月前
|
编解码 前端开发 网络协议
Netty Review - ObjectEncoder对象和ObjectDecoder对象解码器的使用与源码解读
Netty Review - ObjectEncoder对象和ObjectDecoder对象解码器的使用与源码解读
193 0
|
9月前
|
编解码 安全 前端开发
Netty Review - StringEncoder字符串编码器和StringDecoder 解码器的使用与源码解读
Netty Review - StringEncoder字符串编码器和StringDecoder 解码器的使用与源码解读
288 0
|
分布式计算 网络协议 前端开发
【Netty底层数据交互源码】
【Netty底层数据交互源码】
|
Java 容器
【深入研究NIO与Netty线程模型的源码】
【深入研究NIO与Netty线程模型的源码】
|
编解码 弹性计算 缓存
Netty源码和Reactor模型
Netty源码和Reactor模型
118 0
|
设计模式 监控 前端开发
第 10 章 Netty 核心源码剖析
第 10 章 Netty 核心源码剖析
147 0