Java I/O模型发展以及Netty网络模型的设计思想
Java I/O模型发展以及Netty网络模型的设计思想
- I/O模型
- Java BIO
- Java NIO
- Java AIO
- NIO Reactor网络模型
- 单Reactor单线程模型
- 单Reactor多线程模型
- 主从Reactor多线程模型
- Netty通信框架
前言:
BIO、NIO的代码实践参考:Java分别用BIO、NIO实现简单的客户端服务器通信
I/O模型
- I/O:I和O指
input
和output
,输入输出 - 通俗理解:用怎么样的通道进行
数据的发送和接收
- 很大程度上决定程序通信的性能
Java共支持三种I/O模型:BIO,NIO,AIO
BIO:同步阻塞
,一个线程处理一个连接。只要有一个客户端连接到服务器就需要开一个线程。同一个线程的连接和读写操作会阻塞NIO:同步非阻塞
,一个线程处理多个连接。实现方式是客户端的请求事件都会注册到多路复用器(selector)上面,多路复用器进行轮询处理AIO:异步非阻塞
,引入异步通道概念,采用Proactor模式,有效请求事件才会启动线程,特点是先由操作系统完成后才通知服务器程序启动线程,适用于连接数多的长连接请求
Java BIO
流程:
- 服务器启动一个
ServerSocket
- 客户端启动
socket
与服务器通信。服务器需要对每个客户端建立一个线程 - 客户端发出请求后,先咨询服务器有无线程响应,没有则等待
- 有响应,客户端会等待请求结束后再继续执行
Java NIO
主要概念:
- 三大核心:
Channel
(通道),Buffer
(缓冲区),Selector
(多路复用器) - 非阻塞模式:一个线程从通道请求或读取数据时,它仅能得到能用的数据,无可用数据时,不会阻塞线程,可以继续做其他事情,非阻塞写也是一样,不需要等待写入
- 通俗理解:NIO可以做到用一个线程处理多个操作,假设有10000个请求,实际可能只需要开50-100个线程,不像BIO一样必须分配10000个线程
- HTTP2.0也使用了
多路复用技术
,做到了一个连接并发处理多个请求,数量比HTTP1.0大了好几个数量级
Channel(通道),Buffer(缓冲区),Selector(多路复用器)的关系:
- 每个Channel对应一个Buffer
- Selector对应一个线程,一个线程对应多个Channel
- Selector根据不用事件,在各个通道上切换
- Buffer是一个内存块,底层是数组,读写切换需要用flip()
- Channel是双向的,可以返回底层操作系统的情况
Channel:
- BIO的stream是单向的
- Channel是双向的,可以读也可以写
- 常见的Channel还有FileChannel,DatagramChannel,SocketChannel,ServerSocketChannel
- FileChannel:文件读写
- DatagramChannel:UDP读写
- SocketChannel,ServerSocketChannel:TCP读写
NIO编程流程:
- 服务器启动一个
ServerSocket
得到一个ServerSocketChannel
- 创建一个服务器的
Selector
- ServerSocketChannel注册到Selector上,标记为连接事件,Selector监听该事件
- 开始循环
- Selector得到有事件的
SelectorKey
集合,并进行轮询 - 使用SelectorKey上绑定的Channel进行业务处理(连接,读,写)
Java AIO
NIO Reactor网络模型
单Reactor单线程模型
方案:
Selector
是网络编程API,可以实现应用程序对多路链接请求的处理- 服务器用一个
多路复用器
即一个Reactor
监听所有的客户端的请求连接、读、写事件 - 每次处理完连接,会创建一个
Handler
处理连接后的读写业务处理 - Handler负责完成整个读、业务处理、写业务流程
优缺点:
- 代码简单,只有一个线程,清晰明了
- 客户端连接较多时,无法支撑
- 一般的NIO实现样例就是用的这种模型(Java分别用BIO、NIO实现简单的客户端服务器通信)
单Reactor多线程模型
方案:
Selector
是网络编程API,可以实现应用程序对多路链接请求的处理- 服务器用一个多路复用器即一个
Reactor
监听所有的客户端的请求连接、读、写事件 - 每次处理完连接,会创建一个Handler处理连接后的读写业务处理
- Handler只响应事件,读取数据,不做业务处理,分发给
worker
线程池里面的线程处理业务 - worker线程池分配一个线程负责完成业务处理、回传等业务流程
优缺点:
- 可以充分利用多核cpu处理能力
- 多线程数据访问和共享比较复杂
- Reactor同样是单线程,相比于单Reactor单线程模型性能好一些,但是高并发场景同样会遇到性能瓶颈
主从Reactor多线程模型
方案:
Reactor主线程
和Reactor从线程
,主线程负责处理连接事件,从线程负责处理读写事件- 主Reactor通过
Acceptor
处理完连接事件后,主Reactor把连接分给从Reactor处理 - 从Reactor将连接的channel注册到Selector中进行监听,并创建各种
Handler
进行处理 - Handler只响应事件,读取数据,不做业务处理,分发给
worker线程池
里面的线程处理业务 - worker线程池分配一个线程负责完成业务处理、回传等业务流程
优缺点:
- 主线程和从线程数据交互简单,职责明确
- 能处理较大并发量
- 编程复杂度较高
Netty通信框架
主要基于主从Reactor多线程
模型,做了一定的改进,增加了Reactor线程池
,可以多个主线程和多个从线程并发处理
Netty模型图(简单版)
Netty模型图(复杂版)
工作原理:
- netty抽象出两种线程池
BossGroup
,WorkGroup
,分别做连接事件多路复用和网络读写事件多路复用 - BossGroup,WorkGroup都是
NioEventLoopGroup
- NioEventLoopGroup相当于事件循环组,组中有多个
NioEventLoop
事件循环 - NioEventLoop表示一个不断循环的执行处理任务的线程,每个NioEventLoop都有一个
多路复用器Selector
- 每个BossGroup中的NioEventLoop执行步骤是: a. 轮询
accept
事件 b. 处理accept事件,与客户端建立连接,生成channel,并将其注册到某个WorkGroup中的NioEventLoop上的Selector c. 处理任务队列的任务,即runAllTask - 每个WorkGroup中的NioEventLoop执行步骤是: a. 轮询
read
,write
事件 b. 处理read,write事件,主要是处理channel c. 处理任务队列的任务,即runAllTask - 每个WorkGroup中的NioEventLoop处理业务时,会使用
pipeline管道
,pipeline包含了channel,pipeline维护了很多handler处理器
相关文章:

Java I/O模型发展以及Netty网络模型的设计思想
Java I/O模型发展以及Netty网络模型的设计思想 I/O模型Java BIOJava NIOJava AIO NIO Reactor网络模型单Reactor单线程模型单Reactor多线程模型主从Reactor多线程模型 Netty通信框架 前言: BIO、NIO的代码实践参考:Java分别用BIO、NIO实现简单的客户端服…...

智能电网时代:数字孪生的崭露头角
随着科技的不断进步,数字孪生已经开始在电力行业崭露头角,为这个关键的行业带来了前所未有的机遇和潜力。本文就带大家了解一下数字孪生在哪些方面为电力行业做出改变,以及未来的创新应用。 首先,数字孪生可以提高电力系统运营效率…...

每日一题 501二叉搜素树中的众数(中序遍历)
题目 给你一个含重复值的二叉搜索树(BST)的根节点 root ,找出并返回 BST 中的所有 众数(即,出现频率最高的元素)。 如果树中有不止一个众数,可以按 任意顺序 返回。 假定 BST 满足如下定义&a…...

测试理论与方法----测试流程第三个环节:设计测试用例
测试流程第三个环节:设计测试用例:怎么测<——>测试需求的提取:测什么 ### 5、测试用例 描述:测试用例(TestCase):是一份关于【具体测试步骤】的文档,是为了达到最佳的测试效果或高效揭露软件中潜藏的…...

C++多态案例2----制作饮品
#include<iostream> using namespace std;//制作饮品的大致流程都为: //煮水-----冲泡-----倒入杯中----加入辅料//本案例利用多态技术,提供抽象类制作饮品基类,提供子类制作茶叶和咖啡class AbstractDrinking {public://煮水//冲水//倒…...

机械零件保养3d模拟演示打消客户购买顾虑
复杂机械的工作运转是复杂的,想要对机械有深度的理解和迭代,必须了解它的运转原理及参数,复杂机械运行原因教学存在着不可视、系统庞杂及知识点多等弊病,3D虚拟展示是基于web3d网页运行的三维页面,可以将复杂机械运行过…...

SpringBoot的自动装配源码分析
文章目录 一:什么是自动装配二、springboot的启动流程1.调用SpringApplication()的构造方法2.执行核心run方法()3.执行核心prepareContext()4.执行核心refreshContext()5…...

Linux常用命令——csplit命令
在线Linux命令查询工具 csplit 将一个大文件分割成小的碎片文件 补充说明 csplit命令用于将一个大文件分割成小的碎片,并且将分割后的每个碎片保存成一个文件。碎片文件的命名类似“xx00”,“xx01”。csplit命令是split的一个变体,split只…...
React 组件的3大属性: state
state 一、理解二、用途三、使用3.1、类初始化3.2、函数初始化 四、状态读更4.1、组件内部状态管理和数据更新4.2、state 和 props 一起使用 一、理解 组件被称为"状态机", 页面的显示是根据组件的state 属性的数据来显示。 state 是一个用于存储和管理组件内部数据的…...

vscode 上传项目到gitlab
第一步初始化项目 如果没有创建过分支(创建分支这里不记录),默认是master分支: ①将所需要的上传的文件添加到暂存区,如图: ②填写一下注释信息,将暂存区的文件上传到本地分支(没有创…...

[羊城杯 2020] easyphp
打开题目,源代码 <?php$files scandir(./); foreach($files as $file) {if(is_file($file)){if ($file ! "index.php") {unlink($file);}}}if(!isset($_GET[content]) || !isset($_GET[filename])) {highlight_file(__FILE__);die();}$content $_GE…...

QT 常用类与组件
0 思维导图 1 信息调试类(QDebug) #include "widget.h" #include<iostream> //printf #include<QDebug> //qDebuf using namespace std; //coutWidget::Widget(QWidget *parent): QWidget(parent) {//输出函数//使用…...
C#控制台连接Mysql数据库,有配置数据库连接字符串的配置文件
C#控制台连接Mysql数据库,有配置数据库连接字符串的配置文件 实现功能 读取..txt 中的配置文件,来初始化连接字符串让连接字符串的配置文件不存在会主动创建默认的连接字符串 注意点: 需要引用Newtonsoft使用mysql 代码如下 using Syst…...

PowerBuilder连接SQLITE3
PowerBuilder,一个古老的IDE,打算陆续发些相关的,也许还有人需要,内容可能涉及其他作者,但基本都是基于本人实践整理,如涉及归属,请联系. SQLite,轻型数据库,相对与PowerBuilder来说是个新事务,故发数来,以供参考. PB中使用OLE Microsoft OLE DB方式进行连接,如下 // Profile…...

Git 基本原理和常用操作
Git Git 是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。由 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开源的版本控制软件。 Git 常用操作 git 提交流程:工作区 -> git add 到暂存区 -> gi…...
单元测试和集成测试的区别
单元测试和集成测试是软件开发中常用的两种测试方法,它们的主要区别如下: 范围不同:单元测试关注于对软件中的最小功能单元进行测试,通常是对独立的函数、方法或类进行测试。而集成测试则更加综合,涉及多个模块、组件或…...
node基础概念
前言:可以让别人访问我们的网页,可以开发服务端应用、工具类应用、桌面端应用(electron) 1. 计算机基础 概念:CPU 内存 硬盘 主板 显卡 2. 进程和线程 概念:进程是一个程序的执行,线程组合形…...

ArcGIS Maps SDK for JS(二):MapView简介----创建2D地图
文章目录 1 AMD 引用 ArcGIS Maps SDK for JavaScript2 加载相应模块3 创建地图4 创建 2D 视图 view5 确定页面内容6 CSS 样式7 完整代码 本教程使用 AMD 模块,指导您如何在二维地图视图中创建一个简单的地图。 1 AMD 引用 ArcGIS Maps SDK for JavaScript 在 <…...

知识图谱推理研究综述9.3
综述分类 根据样本量大小的不同,将知识图谱推理方法分为多样本推理、少样本推理和零与单样本推理 KG定义:(Y) 知识图谱是以图的形式表示真实世界的实体与关系之间关系的知识库。 具体来说知识图谱是通过将应用数学、图形学、信…...
详细介绍c++中的类
C 中的类是面向对象编程的基本概念,它指的是一种能够封装数据和方法的用户定义数据类型。类是程序中一个重要的概念,它允许程序员通过定义类来实现代码复用、模块化和继承等特性。 C 中的类由以下部分组成: Data members:成员变量…...

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式
一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明:假设每台服务器已…...
应用升级/灾备测试时使用guarantee 闪回点迅速回退
1.场景 应用要升级,当升级失败时,数据库回退到升级前. 要测试系统,测试完成后,数据库要回退到测试前。 相对于RMAN恢复需要很长时间, 数据库闪回只需要几分钟。 2.技术实现 数据库设置 2个db_recovery参数 创建guarantee闪回点,不需要开启数据库闪回。…...
日语学习-日语知识点小记-构建基础-JLPT-N4阶段(33):にする
日语学习-日语知识点小记-构建基础-JLPT-N4阶段(33):にする 1、前言(1)情况说明(2)工程师的信仰2、知识点(1) にする1,接续:名词+にする2,接续:疑问词+にする3,(A)は(B)にする。(2)復習:(1)复习句子(2)ために & ように(3)そう(4)にする3、…...

.Net框架,除了EF还有很多很多......
文章目录 1. 引言2. Dapper2.1 概述与设计原理2.2 核心功能与代码示例基本查询多映射查询存储过程调用 2.3 性能优化原理2.4 适用场景 3. NHibernate3.1 概述与架构设计3.2 映射配置示例Fluent映射XML映射 3.3 查询示例HQL查询Criteria APILINQ提供程序 3.4 高级特性3.5 适用场…...

Linux 内存管理实战精讲:核心原理与面试常考点全解析
Linux 内存管理实战精讲:核心原理与面试常考点全解析 Linux 内核内存管理是系统设计中最复杂但也最核心的模块之一。它不仅支撑着虚拟内存机制、物理内存分配、进程隔离与资源复用,还直接决定系统运行的性能与稳定性。无论你是嵌入式开发者、内核调试工…...

免费PDF转图片工具
免费PDF转图片工具 一款简单易用的PDF转图片工具,可以将PDF文件快速转换为高质量PNG图片。无需安装复杂的软件,也不需要在线上传文件,保护您的隐私。 工具截图 主要特点 🚀 快速转换:本地转换,无需等待上…...

[ACTF2020 新生赛]Include 1(php://filter伪协议)
题目 做法 启动靶机,点进去 点进去 查看URL,有 ?fileflag.php说明存在文件包含,原理是php://filter 协议 当它与包含函数结合时,php://filter流会被当作php文件执行。 用php://filter加编码,能让PHP把文件内容…...
【HarmonyOS 5】鸿蒙中Stage模型与FA模型详解
一、前言 在HarmonyOS 5的应用开发模型中,featureAbility是旧版FA模型(Feature Ability)的用法,Stage模型已采用全新的应用架构,推荐使用组件化的上下文获取方式,而非依赖featureAbility。 FA大概是API7之…...

【免费数据】2005-2019年我国272个地级市的旅游竞争力多指标数据(33个指标)
旅游业是一个城市的重要产业构成。旅游竞争力是一个城市竞争力的重要构成部分。一个城市的旅游竞争力反映了其在旅游市场竞争中的比较优势。 今日我们分享的是2005-2019年我国272个地级市的旅游竞争力多指标数据!该数据集源自2025年4月发表于《地理学报》的论文成果…...
深入理解 React 样式方案
React 的样式方案较多,在应用开发初期,开发者需要根据项目业务具体情况选择对应样式方案。React 样式方案主要有: 1. 内联样式 2. module css 3. css in js 4. tailwind css 这些方案中,均有各自的优势和缺点。 1. 方案优劣势 1. 内联样式: 简单直观,适合动态样式和…...