【Netty】反应器 Reactor 模式 ( 单反应器 Reactor 单线程 | 单反应器 Reactor 多线程 )

简介: 【Netty】反应器 Reactor 模式 ( 单反应器 Reactor 单线程 | 单反应器 Reactor 多线程 )

文章目录

一、 反应器 ( Reactor ) 模式

二、 反应器 ( Reactor ) 模式两大组件

三、 单反应器 ( Reactor ) 单线程

四、 单反应器 ( Reactor ) 单线程 与 NIO 模型对应关系

五、 单反应器 ( Reactor ) 单线程优缺点分析

六、 单反应器 ( Reactor ) 多线程

七、 单反应器 ( Reactor ) 多线程优缺点分析





一、 反应器 ( Reactor ) 模式


反应器 ( Reactor ) 模式 简介 :



① 基于事件驱动 : 多个客户端同时向服务器端传递数据 , 每个客户端传递数据的行为都称为一个事件 , 每个事件都会触发相应操作 ;


② 服务器端处理事件 : 服务器端接收到多个客户端发送的事件请求 , 将这些事件对应的操作分发给对应的线程进行处理 ; 反应器 ( Reactor ) 模式 , 又称为 分发者 ( Dispatcher ) 模式 ;



反应器 ( Reactor ) 模式 中监听客户端请求事件 , 服务器端监听到事件后 , 将事件分发给指定的线程处理 ( 可以是唯一的一个 , 也可以是多个线程中的一个 ) ;






二、 反应器 ( Reactor ) 模式两大组件


反应器 ( Reactor ) 模式 涉及到两个组件 , 反应器 ( Reactor ) 组件 和 处理者 ( Handler ) 组件 ;



1 . 反应器 ( Reactor ) 组件 : 该组件调度分发事件给 处理者 ( Handler ) 组件 , 处理与相应客户端的 IO 事件 ;



① 运行线程 : 反应器 ( Reactor ) 在独立线程中运行 , 该线程只负责事件相关的监听与分发操作 , 不处理具体的业务逻辑 ;


② 监听事件 : 反应器 ( Reactor ) 在线程中监听客户端的请求事件 ;


③ 分发事件 : 反应器 ( Reactor ) 监听到事件后 , 将事件分发给其 处理者 ( Handler ) 组件 处理实际的业务逻辑 ;



2 . 处理者 ( Handler ) 组件 : 该 Handler 组件用于 处理实际的业务逻辑 ;








三、 单反应器 ( Reactor ) 单线程


1 . 单 反应器 ( Reactor ) 单 线程 模型 :



① 客户端 : 向服务器发送请求事件 ;


② 服务器端 反应器 ( Reactor ) : 有两个功能 , 监听 ( Select ) 和 分发 ( Dispatch ) , 监听客户端请求事件 , 获取到事件后 , 将事件分发给 接受者 ( Acceptor ) 或 处理者 ( Handler ) ;


③ 服务器端 接受者 ( Acceptor ) : 负责处理客户端与服务器端建立 Socket 连接的操作 ;


④ 服务器端 处理者 ( Handler ) : 负责与客户端的数据交互 , 执行实际业务处理操作 , 调用 read 方法读取客户端上传的数据 , 并进行相应的业务处理 , 调用 write 方法将服务器的反馈数据发送给客户端 ; ( 读取客户端数据 -> 执行业务处理操作 -> 将结果回送给客户端 )



image.png





四、 单反应器 ( Reactor ) 单线程 与 NIO 模型对应关系


NIO 服务器与客户端通信 , 与上面的 反应器 ( Reactor ) 模式 是对应的 :



① 反应器 ( Reactor ) : NIO 中的 选择器 ( Selector ) 对应 反应器 ( Reactor ) ;


② 接受者 ( Acceptor ) : 反应器 ( Reactor ) 模式中的 接受者 ( Acceptor ) , 对应 NIO 中处理客户端与服务器端的连接事件 ;


③ 处理者 ( Handler ) : NIO 中的选择器 ( Selector ) 监听读取数据事件并进行相应处理 , 对应 处理者 ( Handler ) ;

image.png





五、 单反应器 ( Reactor ) 单线程优缺点分析


1 . 单反应器 ( Reactor ) 单线程 优点 : 单个线程实现 , 模型简单 , 不用考虑线程通信 , 线程同步等问题 ;




2 . 单 反应器 ( Reactor ) 单 线程 模型 弊端 : 除了简单之外 , 全是问题 ;



① 容易出现阻塞 : 该模式下 , 只有一个线程 , 处理者 ( Handler ) 每次只能处理一个客户端的请求事件 , 如果客户端数量很多 , 出现高并发情况 , 只能阻塞等待前面的 处理者 ( Handler ) 将事件处理完毕 , 才能轮到后面的事件开始处理 ;


② 服务器性能 : 一般的服务器都是多核多线程 CPU , 只跑一个线程 , 浪费了大量服务器性能 ;


③ 处理延迟 : 当 处理器 ( Handler ) 处理一个客户端的业务逻辑时 , 无法及时响应其它客户端的连接 , 造成延迟 ;


④ 可靠性问题 : 如果仅有的一个线程运行出现异常 , 整个程序都崩了 ;




3 . 单反应器 ( Reactor ) 单线程 模型 适用场景 : 不容易出现堵塞的场景 , 即连接少 , 处理速度快 的场景 ;



① 客户端数量较少 : 客户端少 , 连接少 , 并发数量不高 ;


② 业务处理速度快 : 每个客户端连接执行的都是耗时较少的操作 ;






六、 单反应器 ( Reactor ) 多线程


1 . 单 反应器 ( Reactor ) 单 线程 模型 :



① 客户端 : 向服务器发送请求事件 ;


② 服务器端 反应器 ( Reactor ) : 该反应器 ( Reactor ) 占用一个单独的线程 , 反应器 ( Reactor ) 有两个功能 , 监听 ( Select ) 和 分发 ( Dispatch ) , 监听客户端请求事件 , 获取到事件后 , 将事件分发给 接受者 ( Acceptor ) 或 处理者 ( Handler ) ;


建立连接请求 , 分发 ( Dispatch ) 给 接受者 ( Acceptor ) ;

处理与客户端业务逻辑 , 分发给 处理者 ( Handler ) ;

③ 服务器端 接受者 ( Acceptor ) : 负责处理客户端与服务器端建立 Socket 连接的操作 ;


④ 服务器端 处理者 ( Handler ) : Handler 只负责响应业务处理的请求事件 , 不处理具体的与客户端交互的业务逻辑 , 因此不会长时间阻塞 , 其调用 read 方法读取客户端数据后 , 将业务逻辑交给 线程池 ( Worker ) 处理相关业务逻辑 , 处理完毕后 , 将结果返回 , Handler 将该结果写出到客户端 ;


⑤ 服务器端 线程池 ( Worker ) : 接收 处理者 ( Handler ) 的请求 , 为将请求对应业务逻辑操作 , 分配给某个独立线程完成 , 执行完成后的结果再次返回给 处理者 ( Handler ) ,


( Handler 读取客户端数据 -> Worker 线程池分配线程执行业务处理操作 -> Handler 将结果回送给客户端 )








七、 单反应器 ( Reactor ) 多线程优缺点分析


1 . 单反应器 ( Reactor ) 多线程 优点 : 充分发挥出服务器多核多线程 CPU 的优势 , 根据 CPU 性能定制线程个数 , 没有性能上的浪费 ;




2 . 单反应器 ( Reactor ) 多线程 缺点 :



① 数据同步 : 线程池 ( Worker ) 中的多个业务逻辑处理线程 , 需要与 处理器 ( Handler ) 共享数据 , 涉及到数据跨线程传输访问 , 比较复杂 ;


② 反应器 ( Reactor ) 负载较大 : 反应器 ( Reactor ) 处理所有的客户端的事件的监听与分发操作 , 其 在单线程中运行 , 如果并发数量很高 , 也是有线程堵塞的性能瓶颈产生 ;


目录
相关文章
|
6月前
|
负载均衡 算法 安全
基于Reactor模式的高性能网络库之线程池组件设计篇
EventLoopThreadPool 是 Reactor 模式中实现“一个主线程 + 多个工作线程”的关键组件,用于高效管理多个 EventLoop 并在多核 CPU 上分担高并发 I/O 压力。通过封装 Thread 类和 EventLoopThread,实现线程创建、管理和事件循环的调度,形成线程池结构。每个 EventLoopThread 管理一个子线程与对应的 EventLoop(subloop),主线程(base loop)通过负载均衡算法将任务派发至各 subloop,从而提升系统性能与并发处理能力。
367 3
|
6月前
|
安全 算法 Java
Java 多线程:线程安全与同步控制的深度解析
本文介绍了 Java 多线程开发的关键技术,涵盖线程的创建与启动、线程安全问题及其解决方案,包括 synchronized 关键字、原子类和线程间通信机制。通过示例代码讲解了多线程编程中的常见问题与优化方法,帮助开发者提升程序性能与稳定性。
310 0
|
6月前
|
数据采集 监控 调度
干货分享“用 多线程 爬取数据”:单线程 + 协程的效率反超 3 倍,这才是 Python 异步的正确打开方式
在 Python 爬虫中,多线程因 GIL 和切换开销效率低下,而协程通过用户态调度实现高并发,大幅提升爬取效率。本文详解协程原理、实战对比多线程性能,并提供最佳实践,助你掌握异步爬虫核心技术。
|
7月前
|
Java 数据挖掘 调度
Java 多线程创建零基础入门新手指南:从零开始全面学习多线程创建方法
本文从零基础角度出发,深入浅出地讲解Java多线程的创建方式。内容涵盖继承`Thread`类、实现`Runnable`接口、使用`Callable`和`Future`接口以及线程池的创建与管理等核心知识点。通过代码示例与应用场景分析,帮助读者理解每种方式的特点及适用场景,理论结合实践,轻松掌握Java多线程编程 essentials。
523 5
|
8月前
|
安全 Java 调度
Netty源码—3.Reactor线程模型二
本文主要介绍了NioEventLoop的执行总体框架、Reactor线程执行一次事件轮询、Reactor线程处理产生IO事件的Channel、Reactor线程处理任务队列之添加任务、Reactor线程处理任务队列之执行任务、NioEventLoop总结。
|
8月前
|
安全 Java
Netty源码—2.Reactor线程模型一
本文主要介绍了关于NioEventLoop的问题整理、理解Reactor线程模型主要分三部分、NioEventLoop的创建和NioEventLoop的启动。
|
11月前
|
Python
python3多线程中使用线程睡眠
本文详细介绍了Python3多线程编程中使用线程睡眠的基本方法和应用场景。通过 `time.sleep()`函数,可以使线程暂停执行一段指定的时间,从而控制线程的执行节奏。通过实际示例演示了如何在多线程中使用线程睡眠来实现计数器和下载器功能。希望本文能帮助您更好地理解和应用Python多线程编程,提高程序的并发能力和执行效率。
438 20
|
3月前
|
Java
如何在Java中进行多线程编程
Java多线程编程常用方式包括:继承Thread类、实现Runnable接口、Callable接口(可返回结果)及使用线程池。推荐线程池以提升性能,避免频繁创建线程。结合同步与通信机制,可有效管理并发任务。
195 6
|
6月前
|
Java API 微服务
为什么虚拟线程将改变Java并发编程?
为什么虚拟线程将改变Java并发编程?
351 83
|
3月前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
391 0