【Linux】事件处理模式

文章目录

服务器框架

  • I/O处理单元:处理客户连接、读写网络数据
  • 逻辑单元:接收数据后应该做什么例如解析数据、封装响应数据
  • 请求队列:各个单元的中介即通信方式
  • 服务器通常要处理三类事件:I/O事件、信号事件(signal/sigaction)以及定时事件(alarm/setitimer),结合I/O多路复用和多线程/多进程,有两种高效的事件处理模式分别是应用于同步的Reactor模式和应用于异步的Proactor模式

Reactor模式

  • 要求主线程只负责监听文件描述符上是否有事件发生,有的话则通知工作线程,交给工作线程来处理。除此之外主线程不做任何其他的工作,接收新的连接、读写数据、处理客户的请求都在工作线程中完成。
  • 工作流程(epoll为例)
      1. epoll_ctl()向内核确定并注册需要监听的文件描述符
      2. 主线程调用epoll_wait()来等待epoll_event就绪事件即等待文件描述符上有数据可读
      3. 当有数据可读时,epoll_wait()通知主线程,主线程将可读事件放入请求队列
      4. 唤醒请求队列的工作线程,从文件描述符读取数据并处理客户请求,然后往epoll内核注册文件描述符上的写就绪事件
      5. 主线程调用epoll_wait()来等待文件描述符上有数据可写
      6. 当有数据可写时,epoll_wait()通知主线程,主线程将可写事件放入请求队列
      7. 唤醒请求队列的工作线程,往文件描述符上写入服务器处理客户请求的结果。

Proactor模式

  • Proactor模式应用于异步I/O中,将所有的I/O操作都交给主线程和内核来进行处理,工作线程仅仅负责业务逻辑即收到数据后应该做什么。
  • 区别于Reactor模式,Proactor模式数据提交到工作线程时已经不需要执行I/O操作,只需要执行逻辑即可

同步I/O模拟Proactor模式

  • 主线程执行监听和数据读写操作,读写完成后向工作线程通知,从工作线程的角度来看,它直接获得了数据I/O的结果,和Proactor模式一样,工作线程只需要进行业务逻辑即可。
相关推荐
IMPYLH5 分钟前
Linux 的 b2sum 命令
linux·运维·服务器·bash
renhongxia110 分钟前
PostTrainBench:LLM 代理能否自动化 LLM 后培训?
运维·人工智能·深度学习·机器学习·架构·自动化·transformer
celeste031026 分钟前
Redis Summary
linux·运维·服务器·redis·笔记
Sylvan.C28 分钟前
Windows+Ubuntu 双系统安装超详细保姆级教程2026,包括系统安装、英伟达独显驱动安装以及双系统时间同步的所有过程
linux·运维·ubuntu
星辰徐哥29 分钟前
鸿蒙金融理财全栈项目——上线与运维、用户反馈、持续迭代
运维·金融·harmonyos
伴我与影29 分钟前
Ubuntu 安装 NVIDIA 显卡驱动
linux·运维·ubuntu
unsynchronized31 分钟前
OpenClaw 安装指南:Linux 与 Windows 系统详细教程
linux·运维·windows·ai
A10169330711 小时前
Nginx 之Rewrite 使用详解
运维·nginx
志栋智能1 小时前
运维超自动化:从成本中心到价值创造者的蜕变
运维·人工智能·自动化
宁波阿成1 小时前
OpenClaw 在 Ubuntu 22.04.5 LTS 上的命令版操作手册
linux·运维·ubuntu·openclaw·龙虾