Reactor模式是什么
一、Reactor模式是什么
反应器设计模式(Reactor pattern)是一种为处理并发服务请求,并将请求提交到一个或
者多个服务处理程序的事件设计模式。当客户端请求抵达后,服务处理程序使用多路分配策略,由一个非阻塞的线程来接收所有的请求,然后派发这些请求至相关的工作线程进行处理。
二、什么场景下使用Reactor模式?
对于高并发系统,常会使用Reactor模式,其代替了常用的多线程处理方式,节省系统
的资源,提高系统的吞吐量。
下面用比较直观的形式来介绍这种模式的使用场景。
以餐厅为例,每一个人就餐就是一个事件,顾客会先看下菜单,然后点餐,处理这些就
餐事件需要服务人员。
就像一个网络服务会有很多的请求,服务器会收到每个请求,然后指派工作线程去处理
一样。
在多线程处理方式下:
一个人来就餐,一个服务员去服务,然后客人会看菜单,点菜。 服务员将菜单给后厨。
二个人来就餐,二个服务员去服务……
五个人来就餐,五个服务员去服务……
这类似多线程的处理方式,一个事件到来,就会有一个线程为其服务。
很显然这种方式在人少的情况下会有很好的用户体验,每个客人都感觉自己享有了最好
的服务。
如果这家餐厅一直这样同一时间最多来5个客人,这家餐厅是可以很好的服务下去的。
由于这家店的服务好,吃饭的人多了起来。
同一时间会来10个客人,老板很开心,但是只有5个服务员,这样就不能一对一服务
了,有些客人就不能马上享有服务员为其服务了。
老板为了挣钱,不得不又请了5个服务员。
现在又好了,每位顾客都享受最好最快的待遇了。
越来越多的人对这家餐厅满意,客源又多了,同时来吃饭的人到了20人,老板高兴但又
高兴不起来了,再请服务员吧,占地方不说,还要开工钱,再请人就挣不到到钱了。
怎么办呢?
老板想了想,10个服务员对付20个客人也是能对付过来的,服务员勤快点就好了,伺候
完一个客人马上伺候另外一个,还是来得及的。
综合考虑了一下,老板决定就使用10个服务人员的线程池!
但是这样又有一个比较严重的缺点:如果正在接受服务员服务的客人点菜很慢,其他的
客人可能就要等好长时间了。
有些脾气火爆的客人可能就等不了走人了。
这样,那就引入了Reactor模式。
那么,Reactor模式是如何处理这个问题呢?
老板后来发现,客人点菜比较慢,大部服务员都在等着客人点菜,其实干的活不是太
多。
老板之所以能当老板当然有点不一样的地方,终于发现了一个新的方法,那就是:当客
人点菜的时候,服务员就可以去招呼其他客人了,等客人点好了菜,直接招呼一声“服
务员”,马上就有个服务员过去服务。
在用了这个新方法后,老板进行了一次裁员,只留了一个服务员!
这就是用单个线程来做多线程的事。
实际的餐馆都是用的Reactor模式在服务。
原文:https://blog.csdn.net/u013219087/article/details/81229873
Reactor模式是什么相关推荐
- Reactor模式与Proactor模式
博主一脚刚踏进分布式的大门(看<分布式Java应用>,如果大家有啥推荐的书欢迎留言~),发现书中对NIO采用的Reactor模式.AIO采用的Proactor模式一笔带过,好奇心趋势我找了 ...
- 高性能IO设计中的Reactor模式与Proactor模式
为什么80%的码农都做不了架构师?>>> 在高性能的IO设计中,有两个比较著名的模式Reactor和Proactor模式,其中Reactor模式用于同步I/O,而Proacto ...
- 高性能IO之Reactor模式
讲到高性能IO绕不开Reactor模式,它是大多数IO相关组件如Netty.Redis在使用的IO模式,为什么需要这种模式,它是如何设计来解决高性能并发的呢? 最最原始的网络编程思路就是服务器用一个w ...
- swing的gui是通过何种模式进行事件响应与监听_【Vert.x准备篇2】C10K问题与Reactor模式...
C10K问题是1999年一个叫Dan Kegel的美国人提出的概念,其中C为concurrently, 10K指的是1万个网络连接, 结合起来意为如何能够做到并发处理1万个连接. 这里首先要澄清一下, ...
- 高性能IO -Reactor模式的实现
2019独角兽企业重金招聘Python工程师标准>>> 在了解Reactor模式之前, 首先了解什么是NIO. java.nio全称java non-blocking IO 即非阻塞 ...
- 【Netty】反应器 Reactor 模式 ( 单反应器 Reactor 单线程 | 单反应器 Reactor 多线程 )
文章目录 一. 反应器 ( Reactor ) 模式 二. 反应器 ( Reactor ) 模式两大组件 三. 单反应器 ( Reactor ) 单线程 四. 单反应器 ( Reactor ) 单线程 ...
- 【Netty】Netty 简介 ( 原生 NIO 弊端 | Netty 框架 | Netty 版本 | 线程模型 | 线程 阻塞 IO 模型 | Reactor 模式引入 )
文章目录 一. NIO 原生 API 弊端 二. Netty 简介 三. Netty 架构 四. Netty 版本 五. Netty 线程模型 六. 阻塞 IO 线程模型 七. 反应器 ( React ...
- Java进阶(五)Java I/O模型从BIO到NIO和Reactor模式
本文介绍了Java中的四种I/O模型,同步阻塞,同步非阻塞,多路复用,异步阻塞.同时将NIO和BIO进行了对比,并详细分析了基于NIO的Reactor模式,包括经典单线程模型以及多线程模式和多Reac ...
- libevent之Reactor模式详解
转自:http://blog.csdn.net/sparkliang/article/details/4957667 前面讲到,整个libevent本身就是一个Reactor,因此本节将专门对Reac ...
- ACE - Reactor模式源码剖析及具体实现(大量源码慎入)
原文出自http://www.cnblogs.com/binchen-china,禁止转载. 在之前的文章中提到过Reactor模式和Preactor模式,现在利用ACE的Reactor来实现一个基于 ...
最新文章
- silverlight 客户端之间的通讯
- android wp8相机,体验提升明显 WP8.1相机对比专业拍摄
- 如何上传应用到百度应用(图解攻略)
- 19道Python练习题
- 全志A33-修改linux kernel启动参数
- NHibernate初学者指南(10):一级和二级缓存
- 多种方法解决Exchange 2010 EMC批量启用邮箱之后出..
- 第四篇、Python文件处理
- android 序列化传参数,Android序列化之Parcelable和Serializable的使用详解
- 下载时,要关闭休眠功能
- DBC 2000 安装
- Newtonsoft动态解析Json数据
- BackTrack4——利用***测试保证系统安全
- Linux原生日志系统Rsyslog详解
- (二十六)树莓派3B+ 获取HMC5883L的磁场数据
- 树莓派触摸屏翻转显示以及触摸翻转
- Netty服务如何写出数据
- kdj值应用口诀_kdj指标怎么用?KDJ值应用口诀(2)
- 宝塔的安全防范-服务器防火墙配置经验分享
- 如何做一个好的项目经理
热门文章
- COMFORT 格调丨白鹿 “非常规”的姿态背后
- python装饰器传参与不传参_Python装饰器不会传参?别着急,这篇文章为你解惑
- 关于深度学习批量处理的一些小Tips(python)
- 乐视盒子新版系统ui3.0如何恢复成出厂系统ui1.5
- JavaScript日期加减,Juqery日期加减计算并赋值给input框
- SAP中MD04中计划独立需求的MRP元素标识与需求类型的关系及应用
- hexo博客超级加速———腾讯cos
- mysql delimiter 异常_MySql中的DELIMITER错误
- 网络层数据包的结构分析
- MySQL项目五,数据查询