首页 > 文档
MC是如何使用多线程和状态机来处理请求命令的?
- 2024-05-30
- 1057 ℃
网络模型:了解了 Mc 的系统架构之后,我们接下来可以逐一深入学习 Mc 的各个模块了。首先,我们来学习 Mc 的网络模型。
主线程:Mc 基于 Libevent 实现多线程网络 IO 模型。Mc 的 IO 处理线程分主线程和工作线程,每个线程各有一个 event_base,来监听网络事件。主线程负责监听及建立连接。工作线程负责对建立的连接进行网络 IO 读取、命令解析、处理及响应。
Mc 主线程在监听端口时,当有连接到来,主线程 accept 该连接,并将连接调度给工作线程。调度处理逻辑,主线程先将 fd 封装成一个 CQ_ITEM 结构,并存入新连接队列中,然后轮询一个工作线程,并通过管道向该工作线程发送通知。工作线程监听到通知后,会从新连接队列获取一个连接,然后开始从这个连接读取网络 IO 并处理,如下图所示。主线程的这个处理逻辑主要在状态机中执行,对应的连接状态为 conn_listening。
上一篇:MC如何淘汰冷key和失效key
下一篇:MC是怎么定位key的
相关内容
移动风暴 ——苹果与...
Linux内核精髓 ——精...
锋利的jQuery
心理学历年真题合集
合肥工业大学超越考研数...
ECSHOP开发手册+使用手册
教师资格证清晨读书计划
伟哥的python私房菜
-
Python 爬虫开发与项目实战
2024-05-29 1151
-
工具应用:使用 clinicj 工具实现通用性安全检查
2024-05-24 1386
-
2012化学专业教师招聘试题
2024-08-20 1440
-
Maven实战
2024-05-24 1267
-
规范汉字字帖·小初高必背古诗文
2024-07-13 1483
-
2012数学专业教师招聘试题
2024-08-20 1072
-
奈特妇产科彩色图谱
2024-06-18 1092
-
内存检查:多种类型的内存泄漏分析方案
2024-05-24 1434
-
【新文道】大学英语四级实力抢分班
2024-08-18 942
-
从容应对亿级QPS访问,Redi还缺少什么?
2024-05-24 1331
文章评论 (0)
- 这篇文章还没有收到评论,赶紧来抢沙发吧~


下载完整资料
点击分享文章