当前位置: 首页 > 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只需要处理被分配到的客户端连接的读写请求。
在这里插入图片描述

http://www.lryc.cn/news/38656.html

相关文章:

  • Git图解-IDEA中的Git操作
  • 在一个web应用中应该如何完成资源的跳转
  • 前缀和部分题目
  • 三天吃透MySQL面试八股文
  • Giving You A guide to learning any topic faster than 95% of people
  • (七十七)大白话MySQL是如何根据成本优化选择执行计划的?(中)
  • 原来CSS 也可以节流啊
  • UE官方教程笔记03-功能、术语、操作简介
  • BN,LN,IN,GN的理解和用法
  • Linux:epoll模式web服务器代码,代码debug
  • SpringSecurity学习(四)密码加密、RememberMe记住我
  • vue专项练习
  • 【笔试题】百度+美团
  • 【8.索引篇】
  • MySQL InnoDB存储引擎锁与事务实现原理解析(未完成)
  • P1683 入门(洛谷)JAVA
  • yocto编译烧录和脚本解析
  • Proteus 8.15安装包安装教程
  • Spring——AOP工作流程
  • c++11多线程之condition_variable、wait()、notify_one()、notify_all()的使用。
  • skywalking扩展实现 —— 监控数据的动态上报
  • 【GoF 23】23种设计模式与OOP七大原则概述
  • Java 日期时间
  • Face Forgery Suvery
  • 案例学习--016 消息队列作用和意义
  • 【MySQL】MySQL的锁机制
  • HTML 背景
  • Lombok
  • Koa源码学习
  • 一种延迟加载自定义元素的方法