首页 > 文档
MC是如何使用多线程和状态机来处理请求命令的?
- 2024-05-30
- 1106 ℃
网络模型:了解了 Mc 的系统架构之后,我们接下来可以逐一深入学习 Mc 的各个模块了。首先,我们来学习 Mc 的网络模型。
主线程:Mc 基于 Libevent 实现多线程网络 IO 模型。Mc 的 IO 处理线程分主线程和工作线程,每个线程各有一个 event_base,来监听网络事件。主线程负责监听及建立连接。工作线程负责对建立的连接进行网络 IO 读取、命令解析、处理及响应。
Mc 主线程在监听端口时,当有连接到来,主线程 accept 该连接,并将连接调度给工作线程。调度处理逻辑,主线程先将 fd 封装成一个 CQ_ITEM 结构,并存入新连接队列中,然后轮询一个工作线程,并通过管道向该工作线程发送通知。工作线程监听到通知后,会从新连接队列获取一个连接,然后开始从这个连接读取网络 IO 并处理,如下图所示。主线程的这个处理逻辑主要在状态机中执行,对应的连接状态为 conn_listening。
上一篇:MC如何淘汰冷key和失效key
下一篇:MC是怎么定位key的
相关内容
TCP/IP路由技术
零基础学编程 零基础学Java
深入理解、应用及扩展 Twemproxy
奈特神经系统疾病彩色图谱
Android的设计与实现
初高中教材电子版
奈特人体解剖彩色图谱
伟哥的python私房菜
-
MC是怎么定位key的
2024-05-24 1502
-
初高中教师资格证面试通关资料大全
2024-08-19 1342
-
漫谈设计模式:从面向对象开始
2024-05-24 1005
-
深入理解Android ——卷I
2024-05-24 1402
-
五笔字型2日速成(五笔+搜狗+五笔字词典)
2024-05-24 1346
-
工具应用:使用 clinicj 工具实现通用性安全检查
2024-05-24 1440
-
2012教育学考试资料
2024-08-20 1192
-
近10年中小幼教资历年考试真题
2024-08-19 1096
-
大学英语四级 2020-2023套试题册+答案速查
2024-08-19 1283
-
奈特简明神经病学
2024-06-18 1134
文章评论 (0)
- 这篇文章还没有收到评论,赶紧来抢沙发吧~


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