Netty是什么

一、Netty介绍

1、Netty是一个异步的、基于事件驱动的网络应用框架,用以快速开发高性能、高可靠性的网络IO程序。

2、Netty主要针对在TCP协议下,面向Clients端的高并发应用,或者Peer-to-Peer场景下的大量数据持续传输的应用。

3、Netty本质是一个NIO框架,适用于服务器通讯相关的多种应用场景。

二、Netty应用场景

1、互联网行业:RPC框架使用、阿里Dubbo协议。

2、游戏行业

3、大数据领域

三、I/O模型

1、BIO:同步阻塞,服务器实现模式为一个连接一个线程,即客户端有连接请求时服务器端就需要启动一个线程进行处理,如果这个连接不做任何事情会造成不必要的线程开销。适用于连接数比较小且固定的架构,这种方式对服务器要求高,并发局限于应用中。

2、NIO:同步非阻塞,服务器实现模式为一个线程处理多个请求(连接),即客户端发送的连接请求都会注册到多路复用器上,多路复用器轮询到连接有IO请求就行处理。

三大核心部分:Channel(通道),Buffer(缓冲区),Selector(选择器)。

3、NIO是面向缓冲或者面向块编程的。数据读取到一个它稍后处理的缓冲区,需要时可在缓冲区中前后移动,这就增加了处理过程中的灵活性,使用它可以提供非阻塞式的高伸缩性网络。

3、AIO:异步非阻塞,AIO引入异步通道的概念,采用了Proactor模式,简化了程序编写,有效的请求才启动线程,他的特点是先由操作系统完成后才通知服务端程序启动线程去处理,一般适用于连接数较多且连接时间较长的应用。

4、BIO工作机制

原理图

四、为什么Netty选择NIO而非AIO

1、在Linux系统上,AIO的底层实现仍然使用的是epoll,没有很好的实现API,在性能上没有明显的优势。同时Linux上AIO不是很成熟,处理回调结果的速度跟不上处理需求。

2、Netty整体架构采用的是Reactor模型,而AIO采用的是Proactor模型,整合相对较乱

3、AIO接收数据时采用的是预分配缓存,而NIO采用的是需要接收时菜分配缓存。AIO在连接数相对较大,而实际流量小的情况下会浪费内存

相关推荐
beiback3 天前
Springboot + netty + rabbitmq + myBatis
spring boot·mysql·rabbitmq·mybatis·netty·java-rabbitmq
山塘小鱼儿11 天前
Netty+HTML5+Canvas 网络画画板实时在线画画
java·前端·网络·netty·html5
学海无涯,行者无疆20 天前
通用接口开放平台设计与实现——(31)API服务线程安全问题确认与修复
接口·netty·开放平台·接口开放平台·通用接口开放平台
马丁的代码日记1 个月前
Netty中用到了哪些设计模式
java·开发语言·设计模式·netty
wang09071 个月前
netty编程之整合es实现存储以及搜索功能
大数据·elasticsearch·搜索引擎·netty
huisheng_qaq1 个月前
【netty系列-09】深入理解和解决tcp的粘包拆包
tcp/ip·网络编程·netty·网络通信·粘包拆包·粘包拆包解决方案
大作业管家1 个月前
netty开发模拟qq斗地主
netty·qq斗地主
huisheng_qaq1 个月前
【netty系列-08】深入Netty组件底层原理和基本实现
java·netty·context·eventloop·channelhandler·netty原理及实现
wang09071 个月前
netty编程之结合springboot一起使用
java·spring boot·netty
长安初雪1 个月前
第一个NIO开发演示
开发语言·netty·nio