78、框架分析------服务器源码解析----云视频服务项目

框架分析

整体流程图

简单解析

绿色为主线程,蓝色为子线程

  1. 主线程启动 epoll 监听新的连接,当有新的连接时通过 eventfd 通知子线程
  2. 主线程启动时会利用EventLoop 启动多个子线程,每个子线程由 IOThread处理
  3. 子线程启动 epoll 监听 eventfd 以及一些已经建立的连接的读写事件
  4. 子线程判断如果为 eventfd,进一步判断分为三种情况,0 为注册新的连接,1 为外部线程投递的发送事件,2 为关闭事件
  5. 如果为新连接则将新连接放入 epoll 中。
  6. 如果为外部投递的发送事件,则判断是否能直接发送,如不能则放入发送队列并监听 EPOLLOUT 事件
  7. 如果为外部投递的关闭事件,则关闭 epoll 监听,子线程退出
  8. 如果不是 event 事件,则判断 epoll 是否返回错误,如果返回错误则清除该描述符,并监听下一个
  9. 如果不是 event 事件,且没有错误,那就是读写事件,分别处理读写请求即可。
  10. 读请求将收到的消息 echo 给对方(可选,测试用)
  11. 写请求又回到 6 的处理逻辑。

类关系图

项目源码

boostasio-learn: boostasio学习笔记 - Gitee.com

相关推荐
我不是懒洋洋1 小时前
【C++】string(string的成员变量、auto和范围for、string常用接口的说明、OJ题目、string的模拟实现)
c语言·开发语言·c++·visual studio
Brilliantwxx1 小时前
【C++】 C++11 知识点梳理(中)
开发语言·c++
j7~1 小时前
【C++】STL--Vector容器--拆析解剖Vector的实现以及Vector的底层详解(2)
开发语言·c++·动态二维数组·vector深度剖析·vector的实现·杨辉三角形
旖-旎2 小时前
《LeetCode 130 被围绕的区域 FloodFill DFS 解法》
c++·算法·深度优先·力扣·floodfill
云飞云共享云桌面9 小时前
传统工作站 vs 云飞云共享云桌面:制造业设计云桌面选型深度对比
运维·服务器·前端·网络·3d·架构·制造
一只旭宝10 小时前
【C++入门精讲22】常见设计模式
c++·设计模式
JAVA面经实录91710 小时前
操作系统面试题
java·服务器·数据库·计算机网络·面试
小刘|11 小时前
Spring AI Alibaba 集成和风天气 API 实战
java·服务器·前端
c++之路11 小时前
Bazel C++ 构建系列文档(三):构建第一个 C++ 项目
开发语言·c++