码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Reactor模型


    Reactor模型

    Reactor 模型是编写高性能网络服务器的必备技术之一,Reactor 释义“反应堆”,是一种事件驱动机制。

    Reactor 把即将发生的事件和事件的处理过程做了一个映射,逆置了事件处理流程,事件的检测和处理不再是交给我们来处理,我们只需要提供相应事件的处理接口注册到reactor上,如果相应的事件发送,Reactor将主动调用注册的接口,这些接口也可称回调函数。

    Reactor模型的优点:

    1. 响应快,不必为单个同步时间所阻塞,虽然Reactor 本身依然是同步的;
    2. 编程相对简单,可以最大程度的避免复杂的多线程及同步问题,并且避免了多线程/进程的切换开销;
    3. 可扩展性,可以方便的通过增加 Reactor 实例个数来充分利用 CPU 资源;
    4. 可复用性,Reactor模型本身与具体事件处理逻辑无关,具有很高的复用性;

    重要组件:Event事件、Reactor反应堆、Demultiplex事件分发器、Eventhandler事件处理器
    在这里插入图片描述
    上面这张图就很清楚的交代了Reactor模型各组件间交互的流程。
    首先用户先把关注的事件和对应的处理函数注册到Reactor反应堆当中,Reactor反应堆中维护事件和对应事件处理映射的Event集合。
    Demultiplex事件分发器实际上就是一个IO复用接口,如select、poll、epoll_wait,Reactor可以通过往IO复用对象中注册、修改和删除事件。
    然后就是启动反应堆,开启事件循环,检测发生的事件。
    Demultiplex事件分发器把发生的事件返回给Reactor,Reactor通过事件和处理函数的映射调用对应的Eventhandler事件处理器。

    上面介绍的是单Reactor模型,工作在单线程环境下。还可以拓展成多Reactor(Multiple Reactors)模型,充分利用多核CPU的性能。muduo网络库就可以根据用户设定工作线程的数量,来确定开几个Reactor。

    Multiple Reactors实际上就是把各个Reactor的主要任务做了拆分,mainReactor一般为1个,主要负责处理即将到来的新连接,把建立的句柄注册到subReactor上,然后subReactor负责处理已连接句柄的读写事件。
    在这里插入图片描述

  • 相关阅读:
    2011-2021年“第四期”数字普惠金融指数与上市公司匹配(根据省份匹配)/上市公司数字金融指数匹配
    SAP MM 为UB类型的STO执行VL10B,报错-没有项目类别表存在(表T184L NL 0002 V)-之对策
    Web前端:20大新AngularJS开发工具
    【设计模式】六、建造者模式
    Ora2Pg工具迁移Oracle到openGauss
    数据仓库面试题——介绍下数据仓库
    容易理解的归并排序(C语言)
    LG P3990 【SHOI2013】 超级跳马 解题报告
    基于改进灰狼算法优化核极限学习机的锂电池动力电池荷电状态估计
    骚操作之 持有 ReadOnlySpan 数据
  • 原文地址:https://blog.csdn.net/weixin_43973403/article/details/126130713
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号