当前位置: 首页 > news >正文

Reactor模式

Reactor是一种设计模式,可以用于构建高并发的网络服务器。
Reactor模式的好处在于:可以在一个或多个reactor线程使用多路复用技术去管理所有网络连接连接建立、IO请求,保证工作线程不被IO阻塞。
前置知识:IO多路复用技术

1. 传统网络线程模型

在这里插入图片描述
如图所示,传统网络线程模型在每个客户端连接建立完成之后,会为这个客户端连接船舰一个新的线程去处理IO请求,以及进行计算。这种模式实际上对应了我们之前说过的BIO,也就是说,每个线程在客户端数据准备阶段都是被阻塞的,虽然这段时间线程什么都不需要干,但是它却无法脱身。

这样的网络模型既浪费线程资源,又受制于线程数量。

2. Reactor模型

reactor模型实际上就是对前文提到的epoll机制的封装。我们使用reactor线程去处理客户端的连接、IO事件;使工作线程从IO中抽身,只专注于事件的处理。Reactor线程会遍历所有客户端连接,一旦发现其中数据准备完毕,便会将事件分发给工作线程,由工作线程完成后续处理。

根据Reactor线程数量,Reactor模型可以被分为三种:单Reactor单线程、单Reactor多线程、主从Reactor。

2.1 单Reactor单线程

在这里插入图片描述
在这个模式中,只有一个Reactor线程,Reactor既要处理客户端连接,又要进行处理IO,在得知某些连接的IO准备完毕之后,Reactor线程还需要对对应的事件进行处理。

2.2 单Reactor多线程

在上面的单Reactor单线程模型中,Reactor确实可以使用epoll机制监听多个连接,但是对于业务处理,它还是需要串行处理的;如果业务处理很耗时,或者业务量比较大,单Reactor单线程模型就力不从心了。

解决办法页很简单,Reactor线程仅仅处理客户端的连接建立、IO操作。当监测到某些连接的数据就绪时,将业务处理交给一个多线程线程池去处理。
在这里插入图片描述

2.3 多Reactor多线程模型

当客户端连接很多,单个Reactor线程无法应对所有连接的建立、IO操作时,我们使用计算机领域的经典思想:负载均衡。我们使用多个Reactor线程去处理IO操作,将Reactor线程分为一个MainReactor和多个SubReactor。MainReactor负责接收客户端请求,然后acceptor将客户端的连接负载均衡配分到多个SubReactor上,每个SubReactor只需要处理被分配到的客户端连接的读写请求。
在这里插入图片描述

相关文章:

Reactor模式

Reactor是一种设计模式,可以用于构建高并发的网络服务器。 Reactor模式的好处在于:可以在一个或多个reactor线程使用多路复用技术去管理所有网络连接连接建立、IO请求,保证工作线程不被IO阻塞。 前置知识:IO多路复用技术 1. 传统网…...

Git图解-IDEA中的Git操作

目录 一、配置Idea 二、项目克隆 三、文件状态识别 四、Git操作 4.1 git add--添加暂存区 4.2 git commit--提交本地仓库 4.3 git push--推送远程仓库 4.4 git pull--更新本地仓库 五、完整开发流程 5.1 步骤1:克隆项目 5.2 步骤2:创建自己开发…...

在一个web应用中应该如何完成资源的跳转

在一个web应用中通过两种方式,可以完成资源的跳转: 第一种方式:请求转发 第二种方式:重定向 转发和重定向的区别: 代码上的区别: 请求转发 // 获取请求转发器对象 RequestDispatcher dispatcher request.…...

前缀和部分题目

前缀和 前缀和指数组的前 N项之和,是个比较基础的算法 例题 面试题 17.05. 字母与数字 给定一个放有字母和数字的数组,找到最长的子数组,且包含的字母和数字的个数相同。 返回该子数组,若存在多个最长子数组,返回左…...

三天吃透MySQL面试八股文

本文已经收录到Github仓库,该仓库包含计算机基础、Java基础、多线程、JVM、数据库、Redis、Spring、Mybatis、SpringMVC、SpringBoot、分布式、微服务、设计模式、架构、校招社招分享等核心知识点,欢迎star~ Github地址:https://github.com/…...

Giving You A guide to learning any topic faster than 95% of people

A guide to learning any topic faster than 95% of people: Richard Feynman was a physician who won the Nobel Prize in 1965. But he became known for his great lectures. Why? He was able to explain complex concepts in simple terms with these 4 steps: 1 • E…...

(七十七)大白话MySQL是如何根据成本优化选择执行计划的?(中)

上次我们讲完了全表扫描的成本计算方法,相信大家应该都理解了,其实还是比较简单的,今天我们来讲一下索引的成本计算方法,因为除了全表扫描之外,还可能多个索引都可以使用,但是当然同时一般只能用一个索引&a…...

原来CSS 也可以节流啊

Ⅰ、前言 「节流」 是为了减少请求的触发频率,不让用户点的太快,达到节省资源的目的 ;通常 我们采用 JS 的 定时器 setTimeout ,来控制点击多少秒才能在触发;其实 通过 CSS 也能达到 「节流」 的目的,下面…...

UE官方教程笔记03-功能、术语、操作简介

对官方教程视频[官方培训]03-UE功能、术语、操作简介 | 徐良安 Epic的笔记这一部分基本都是走马观花的简单介绍功能世界创建建模Mesh editingtool是一个全新的建模工具,具备大多数的主流建模软件的核心功能HOUDINI ENGINE FOR UNREALHoudini编辑器,可以用…...

BN,LN,IN,GN的理解和用法

绿色区域表示将该区域作用域(四种方法都贯穿了w,h维度),即将该区域数值进行归一化,变为均值为0,标准差为1。BN的作用区域时N,W,H,表示一个batch数据的每一个通道均值为0,标准差为1;LN则是让每个数据的所有channel的均值…...

Linux:epoll模式web服务器代码,代码debug

源码&#xff1a; https://blog.csdn.net/weixin_44718794/article/details/107206136 修改的地方&#xff1a; 修改后代码&#xff1a; #include <stdio.h> #include <unistd.h> #include <stdlib.h> //#include “epoll_server.h” #ifndef _EPOLL_SER…...

SpringSecurity学习(四)密码加密、RememberMe记住我

文章目录密码加密一、简介密码为什么要加密常见的加密解决方案PasswordEncoder详解DelegatingPasswordEncoder二、自定义加密方式1. 使用灵活的密码加密方案&#xff08;BCryptPasswordEncoder&#xff09;加密验证&#xff08;推荐&#xff09;需要在密码前指定加密类型{bcryp…...

vue专项练习

一、循环实现一个列表的展示及删除功能 1.1 列表展示 1、背景&#xff1a; 完成一个这样的列表展示。使用v-for 循环功能 id接口名称测试人员项目名项目ID描述信息创建时间用例数1首页喵酱发财项目a1case的描述信息2019/11/6 14:50:30102个人中心张三发财项目a1case的描述信…...

【笔试题】百度+美团

发工资 链接&#xff1a;https://www.nowcoder.com/questionTerminal/e47cffeef25d43e3b16c11c9b28ac7e8 来源&#xff1a;牛客网 小度新聘请了一名员工牛牛, 每个月小度需要给牛牛至少发放m元工资(给牛牛发放的工资可以等于m元或者大于m元, 不能低于m)。 小度有一些钞票资金…...

【8.索引篇】

索引分类 索引和数据就是位于存储引擎中&#xff1a; 按「数据结构」分类&#xff1a;Btree索引、Hash索引、Full-text索引。按「物理存储」分类&#xff1a;聚簇索引&#xff08;主键索引&#xff09;、二级索引&#xff08;辅助索引&#xff09;。按「字段特性」分类&#…...

MySQL InnoDB存储引擎锁与事务实现原理解析(未完成)

InnoDB MySQL存储引擎是基于表的&#xff0c;也就是说每张表可以选择不同的存储引擎。 InnoDB存储引擎的表是索引组织的&#xff0c;也就是数据即索引。 存储引擎文件 InnoDB引擎会包含RedoLog重做日志文件和TableSpace表空间文件。 表空间文件 默认表空间文件&#xff08…...

P1683 入门(洛谷)JAVA

题目描述&#xff1a; 不是任何人都可以进入桃花岛的&#xff0c;黄药师最讨厌像郭靖一样呆头呆脑的人。所以&#xff0c;他在桃花岛的唯一入口处修了一条小路&#xff0c;这条小路全部用正方形瓷砖铺设而成。有的瓷砖可以踩&#xff0c;我们认为是安全的&#xff0c;而有的瓷砖…...

yocto编译烧录和脚本解析

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录前言一、初始化构建目录二、imx-setup-release.sh脚本解析三、编译单独编译内核四、烧录总结前言 本篇文章主要讲解如何在下载好源码之后进行编译和yocto的脚本解析…...

Proteus 8.15安装包安装教程

Proteus介绍Proteus的介绍Proteus8.15安装包Proteus8.15安装教程Proteus的介绍 Proteus是英国著名的EDA工具(仿真软件)&#xff0c;从原理图布图、代码调试到单片机与外围电路协同仿真&#xff0c;一键切换到PCB设计&#xff0c;真正实现了从概念到产品的完整设计。是世界上唯…...

Spring——AOP工作流程

AOP就是代理模式的开发简化 1.Spring容器启动 因为AOP是要将通知类作为一个bean对象交给spring进行管理的&#xff0c;还有经过通知类被增强的类。 此时还没有创建bean对象 2.读取所有切面配置中的切入点 在下面这段代码中&#xff0c;定义了两个切入点&#xff0c;但是只…...

WinMD:跨平台存储架构的突破性实现与Windows访问Linux RAID解决方案深度解析

WinMD&#xff1a;跨平台存储架构的突破性实现与Windows访问Linux RAID解决方案深度解析 【免费下载链接】winmd WinMD 项目地址: https://gitcode.com/gh_mirrors/wi/winmd 在当今混合IT环境中&#xff0c;Windows访问Linux RAID已成为系统管理员和技术决策者面临的关键…...

5大核心功能揭秘:如何用LeagueAkari游戏辅助工具提升竞技水平

5大核心功能揭秘&#xff1a;如何用LeagueAkari游戏辅助工具提升竞技水平 【免费下载链接】League-Toolkit An all-in-one toolkit for LeagueClient. Gathering power &#x1f680;. 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit LeagueAkari是一款基…...

告别XML解析焦虑:用TinyXML2在C++项目中轻松读写配置文件(附完整代码)

告别XML解析焦虑&#xff1a;用TinyXML2在C项目中轻松读写配置文件&#xff08;附完整代码&#xff09; 在C开发中&#xff0c;配置文件管理是每个项目都无法绕开的环节。当我们需要保存用户偏好、游戏设置或系统参数时&#xff0c;选择一种合适的配置格式往往成为第一个技术决…...

Sunshine游戏串流服务器完整指南:三步搭建个人游戏云

Sunshine游戏串流服务器完整指南&#xff1a;三步搭建个人游戏云 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine Sunshine是一款强大的开源自托管游戏串流服务器&#xff0c;专为M…...

环境配置与基础教程:多机多卡分布式训练实战:基于 SLURM 集群调度 YOLOv11,大幅缩短训练周期

一、为什么分布式训练是 YOLOv11 落地的“必经之路” 1.1 单卡训练的困境 如果你正在使用 YOLOv11 做目标检测,那么你一定遇到过这个场景:数据集有十万张以上的图片,模型选的是 YOLOv11x,单张 A100 跑一个 epoch 要 40 分钟,完整训练 300 个 epoch 需要整整 8 天。更让人…...

终极QMC解码器实战指南:3分钟快速解锁QQ音乐加密文件

终极QMC解码器实战指南&#xff1a;3分钟快速解锁QQ音乐加密文件 【免费下载链接】qmc-decoder Fastest & best convert qmc 2 mp3 | flac tools 项目地址: https://gitcode.com/gh_mirrors/qm/qmc-decoder 你是否曾经下载了QQ音乐平台的歌曲&#xff0c;却发现文件…...

X鱼屏蔽codex后,我的优质token粮仓告急

自从codex被X鱼全面封杀下架&#xff0c;我的优质token来源就又少了关键来源渠道了&#xff0c;多么怀念40元90刀每天额度月卡&#xff0c;30元1000刀的日子&#xff0c;看着其它中转站那些0.15元/刀&#xff0c;0.3元/刀&#xff0c;百万token等于4刀左右吧。一点兴趣都没有&a…...

基于OpenTelemetry的LLM应用可观测性实践:从黑盒到透明化

1. 项目概述&#xff1a;当LLM应用遇见可观测性如果你正在开发或运维基于大语言模型&#xff08;LLM&#xff09;的应用&#xff0c;那么你一定遇到过这样的场景&#xff1a;用户反馈“AI回答得不对”&#xff0c;或者“响应突然变慢了”。当你一头扎进日志和监控系统&#xff…...

Python日志系统设计:从基础到企业级实践

Python日志系统设计&#xff1a;从基础到企业级实践 引言 日志系统是后端应用的重要组成部分&#xff0c;它记录系统运行状态、帮助排查问题、追踪用户行为。Python的logging模块提供了强大的日志功能&#xff0c;但在实际应用中需要合理设计才能发挥最大价值。 本文将深入探讨…...

写了三年CRUD我觉得自己废了,直到产品经理说了一句话

2024年秋天&#xff0c;我在工位上改一个按钮的颜色。从#1890FF改成#4096FF&#xff0c;产品经理说原来的颜色「太老气了」。改完之后&#xff0c;我盯着屏幕发了十分钟的呆。不是因为这个需求有多难&#xff0c;而是我突然意识到&#xff0c;这是我今天写的第四个CSS微调了。上…...