Reactor模型学习笔记

Reactor模型概述

The reactor design_pattern is an event_handling pattern for handling service requests delivered concurrently to a service handler by one or more inputs. The service handler then demultiplexes the incoming requests and dispatches them synchronously to the associated request handlers.
from wiki

从wiki百科中可以得知,Reactor是一种设计模式,并且基于事件驱动
特点:

  1. Reactorservice handlerrequests handlers组成
  2. 一个service handler能够处理多个输入
  3. service handler负责监听IO并且将事件分发给相应的requests handlers处理

为了简述方便,在后续中以Reactor代指service handlerHandler代指request handlers

为什么要使用reactor

传统模型的不足

传统模型采用一个客户对应一个连接,在面对大量客户连接时,创建线程数量多,造成资源浪费,且产生大量上下文切换,非常消耗cpu资源,此时反应器设计模式出场了。

单Reactor单线程模型

Reactor模型基于IO复用模型,可以实现一个线程阻塞监听多个连接,且当连接到来时,由内核通知该线程去处理。此时线程将受到的连接分发给对应的处理器处理。

ReactorHandlers
监听事件(accept)take over(线程a)
响应事件(read、send)take over(线程a)
业务处理事件take over(线程a)

优点:

相对于传统模型,提升客户连接的吞吐量,适用于主要为主存IO的业务场景

缺点:

无法应对大量耗时的外存IO请求(read操作耗时),会导致事件堆积,从而导致连接超时

单Reactor多线程模型

为了提高服务器性能,并且充分利用多核处理器,此时,在单Reactor单线程模型的基础上,将业务处理事件抽离出单线程中,并且插入线程池中运行

ReactorHandlers
监听事件(accept)take over(线程a)
响应事件(read、send)take over(线程a)
业务处理事件take over(线程池)

优点:

在单Reactor单线程模型下提高了性能与可靠性

缺点:

由于监听事件响应事件处于同一线程,当有大量客户请求接入时响应事件就无法及时得到处理,并且当有大量响应事件触发时,监听事件就无法处理

多Reactor多线程模型(主从Reactor模型)

在单Reactor多线程模型下将监听事件响应事件分离,使用一个Reactor处理监听事件多个Reactor处理响应事件

ReactorHandlers
监听事件(accept)take over(线程a)
响应事件(read、send)take over(线程b、线程c....)
业务处理事件take over(线程池)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值