Netty介绍

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

图 1    Netty服务框架

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

lReactor单线程模型

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

图 2    Netty Reactor单线程模型

lReactor多线程模型

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

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

图 3    Netty Reactor多线程模型

l主从Reactor多线程模型

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

图 4    Netty主从Reactor多线程模型

时间: 2024-08-09 14:41:17

Netty介绍的相关文章

第一章:Netty介绍

1. Netty介绍  Netty是一款异步的事件驱动的网络应用程序框架,支持快速地开发可维护的高性能的面向协议的服务器和客户端,Netty是基于NIO实现的,所以整个Netty都是异步操作,网络应用程序通常需要有较高的可扩展性,无论是Netty还是其他的基于Java NIO的框架,都会提供可扩展性的解决方案. 2. 为什么使用Netty? Netty是业界最流行的NIO框架之一,它的健壮性.功能.性能.可定制性和可扩展性在同类框架中都是首屈一指的,它已经得到成百上千的商用项目验证,例如Hado

002——Netty之Netty介绍

Netty出现背景 Java NIO难用 据说存在bug 业界其他NIO框架不成熟 Netty主要解决两个相应关注领域 (1)异步和事件驱动的实现. (2)一组设计模式,将应用逻辑与网络层解耦. 特性 统一API,适用于不同协议 基于灵活.可扩展的事件驱动模型 高度可定制的线程模型 更好的吞吐量,低延迟 尽量减少不必要的内存拷贝 高性能 同步非阻塞,基于Reactor模型实现 TCP接收和发送缓冲区使用直接内存代替堆内存 通过内存池循环利用ByteBuf,避免频繁创建和销毁带来的性能损耗 逻辑架

用Netty开发中间件:网络编程基础

用Netty开发中间件:网络编程基础 <Netty权威指南>在网上的评价不是非常高,尤其是第一版,第二版能稍好些?入手后高速翻看了大半本,不免还是想对<Netty权威指南(第二版)>吐槽一下: 前半本的代码排版太糟糕了,简直就是直接打印Word的版式似的. 源代码解析部分的条理性和代码排版好多了,感觉比其它部分的质量高多了. 假设你是刚開始学习的人可能会感觉非常具体,差点儿每部分都会来一套client和服务端的Demo.假设你不是入门者的话可能会感觉水分比較多. 最后一部分高级特性

netty开发教程(一)

Netty介绍 Netty is an asynchronous event-driven network application framework for rapid development of maintainable high performance protocol servers & clients. netty 官网如是说.大概意思是netty 是一个异步的事件驱动的网络应用框架,能够高速开发可维护的高性能网络server.client应用. asynchronous异步,net

Netty学习记录

一.Netty简介 Netty 是一个基于 JAVA NIO 类库的异步通信框架,它的架构特点是:异步非阻塞.基于事件驱动.高性能.高可靠性和高可定制性. Netty 是一个 NIO client-server(客户端服务器)框架,使用 Netty 可以快速开发网络应用,例如服务器和客户 端协议. Netty 提供了一种新的方式来使开发网络应用程序,这种新的方式使得它很容易使用和有很强的扩展性. Netty 是一个利用 Java 的高级网络的能力,隐藏其背后的复杂性而提供一个易于使用的 API

Netty教程在线观看

<物联网核心技术之Netty入门到精通课程> 课程观看地址:http://www.xuetuwuyou.com/course/14 课程大纲: 第一节:Netty入门到精通--物联网行业介绍及前景分析 第二节:Netty入门到精通--网络编程基本概念. 第三节:Netty入门到精通--Socket服务端和客户端编程 第四节:Netty入门到精通--UDP通信 第五节:Netty入门到精通--URL编程以及物联网常用协议TCP UDP HTTP 对比 第六节:Netty入门到精通--Netty介

netty开发笔记

对netty 和 nio的认识尚浅,分享最近所学到的一些知识,不对的地方还望指正. Netty介绍 Netty is an asynchronous event-driven network application framework for rapid development of maintainable high performance protocol servers & clients. netty 官网如是说,大概意思是netty 是一个异步的事件驱动的网络应用框架,可以快速开发可维

Netty(一):入门篇

匠心零度 转载请注明原创出处,谢谢! 说在前面 上篇文章对Netty进行了初探:Netty初探,主要介绍了下我们为什么需要学习netty.netty介绍等:本篇文章接着上篇文章的内容.本篇为了方便大家快速入门.了解实践Netty特性.快速上手一个例子让大家有一个比较直接的认识. 主题 版本选择及说明 快速入门 总结 版本选择及说明 版本的选择,这是一个很直接但是又经常需要面对的问题,特别是开源项目的时候,我们在选择版本的时候有很多考虑,比较jdk各个版本选择.zookeeper版本的选择.Tom

【Netty】NIO框架Netty入门

Netty介绍 Netty是由JBOSS提供的一个java开源框架.Netty提供异步的.事件驱动的网络应用程序框架和工具,用以快速开发高性能.高可靠性的网络服务器和客户端程序. 也就是说,Netty 是一个基于NIO的客户.服务器端编程框架,使用Netty 可以确保你快速和简单的开发出一个网络应用,例如实现了某种协议的客户,服务端应用.Netty相当简化和流线化了网络应用的编程开发过程,例如,TCP和UDP的socket服务开发. 官网地址:http://netty.io/ 使用场景 Nett