博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Reactor-反应器模式
阅读量:4355 次
发布时间:2019-06-07

本文共 979 字,大约阅读时间需要 3 分钟。

Reactor模式:反应器模式,是高性能网络服务器中最为常用的一种模式,libevent,muduo,libuv等网络库都是以

Reactor模式构建。Reactor模式由同步事件多路分解器和具体事件处理程序组成,同步事件多路分解器一般都是

由操作系统支持,如支持IO复用的select,epoll,poll等,通过监听IO事件集合,根据事件类型将具体事件交由具体

事件处理程序来处理,从而达到结构模块化的处理。总之Reactor是很多高性能网络架构的基础,需要我们开发者

重点学习。

下面是Reactor模式的类图:

以select作为同步事件多路分解器为例:

Reactor handle_events 使用select监听一组套接字,由Event Handler封装套接字和事件组。

 

场景、客户端套接字连接服务器,向服务器发送一条数据,并接受回显这条数据。 

1) 服务器调用register_handler注册accept的Listen套接字

2) 服务器调用handle_events进入事件循环

3) 调用select以处理客户端的登录连接请求

4) 客户端connect连接到服务器

5) 服务器select监听到客户端的连接事件到来,调用事件处理函数handle_event处理新连接的socket

6) 创建新的socket,并将socket Event handle register到 Reactor,并指定socket Event handle当有读事件发生时,通知它

7) 客户端发送一段字符串到服务器,同步事件多路分解器调用handle_events监听到有读事件到来,通知socket Event handle接受数据

8) 数据接受完成后,向socket Event handler register到 Reactor,并指定socket Event handle当有写事件发生时,通知它

9) 客户端调用recv函数回显接受数据

10)服务器同步事件多路分解器调用handle_events监听到有写事件到来,通知socket Event handle 发送之前接受到的数据。

11) 客户端收到数据显示

转载于:https://www.cnblogs.com/Forever-Kenlen-Ja/p/8441030.html

你可能感兴趣的文章
大庆金桥帆软报表案例
查看>>
方维分享系统,个人中心杂志社显示我的、关注的、推荐的数量
查看>>
JavaScript BOM加载事件
查看>>
Java复习总结——详细理解Java反射机制
查看>>
Navicat for MySQL10.1.7注册码
查看>>
Proxy模式
查看>>
读书多些会怎样
查看>>
浏览器好用的技术
查看>>
HDU 2188------巴什博弈
查看>>
tp5任务队列使用supervisor常驻进程
查看>>
Xmind?
查看>>
spring+quartz 实现定时任务三
查看>>
day2-三级菜单
查看>>
java retry_java里面的retry:
查看>>
linux下升级4.5.1版本gcc
查看>>
Beanutils
查看>>
FastJson
查看>>
excel4j
查看>>
Thread
查看>>
HtmlEmail
查看>>