MC系统架构是如何布局的?
Mc 基于 Libevent 开发实现了多线程网络模型。Mc 的多线程网络模型分为主线程、工作线程。这些线程通过多路复用 IO 来进行网络 IO 接入以及读写处理。在 Linux 下,通常使用 epoll。通过多路复用 IO,特别是 epoll 的使用,Mc 线程无须遍历整个被侦听的描述符集,只要在被通知后遍历 Ready 队列的描述符集合就 OK 了。这些描述符是在各项准备工作完成之后,才被内核 IO 事件异步通知。也就是说,只在连接做好准备后,系统才会进行事件通知,Mc 才会进行 I/O 操作。这样就不会发生阻塞,使 Mc 在支持高并发的同时,拥有非常高的 IO 吞吐效率。
Mc 除了用于 IO 的主线程和工作线程外,还用于多个辅助线程,如 Item 爬虫线程、LRU 维护线程、哈希表维护线程等,通过多线程并发工作,Mc 可以充分利用机器的多个核心,实现很好的网络 IO 性能和数据处理能力。
Mc 通过哈希表即 Hashtable 来快速定位 key。数据存储时,数据 Item 结构在存入 slab 中的 chunk 后,也会被存放到 Hashtable 中。同时,Mc 的哈希表会在每个桶,通过 Item 记录一个单向链表,以此来解决不同 key 在哈希表中的 Hash 冲突问题。 当需要查找给定 key 的 Item 时,首先计算 key 的 Hash 值,然后对哈希表中与 Hash 值对应的 bucket 中进行搜索,通过轮询 bucket 里的单向链表,找到该 key 对应的 Item 指针,这样就找到了 key 对应的存储 Item
-
菲菲更名宝贝_FFRenamePro v4.0_批量文件处理工具
『菲菲更名宝贝』是一款优秀的批量更名软件和批量文件处理工具,是获奖软件。软件以功能强大著称,在国内文件处理和批量更名类软件中占有一... 2262 0 24-06-01 -
IT书单小程序
【IT书单微信小程序】是一个包含微信小程序开发源代码和相关截图的资源包,主要针对那些想要学习或构建类似应用的IT从业者。这个项目提供了... 971 0 24-09-16 -
ThinkPhp_V5.0.5 程序源码
ThinkPHP V5.0是一个为API开发而设计的高性能框架——是一个颠覆和重构版本,采用全新的架构思想,引入了很多的PHP新特性,优化了核心,减... 1250 0 24-05-24 -
丰巢存包 - 旅行存包不麻烦
一个月30块搞定,方便又便宜下单前有抵扣金减免,3-6块钱大概如果你旅行需要存包,不想麻烦找地方,丰巢是个不错的选择。它的优势有:1.随... 918 0 24-11-18 -
心中无码,自然高清
短视频平台视频去水印的问题。这些视频除了我们自己剪辑以外,剩下的就是搬运了。无论你是从小红书还是抖音,或者是微博,都能找到很多这些... 916 0 25-03-10 -
Umi-OCR 一款强大的开源光学字符识别(OCR)工具
Umi-OCR是一款强大的开源光学字符识别(OCR)工具,致力于打破现实与数字世界的界限,通过先进的算法,实现对各类复杂图像中的文字信息进行... 991 0 25-02-05 -
SkinFiner_2.0_64bit 超快速人像磨皮软件插件
SkinFiner 是一款超快速人像一键AI全自动磨皮插件,SkinFiner 号称是最快的人像皮肤修饰软件/插件,可以自动皮肤平滑,快速肤色,天然肤... 790 0 25-04-11 -
2025年文道护理综合考研资料
10-12章刷题课68pptx.pptx10-12章节练习题doc.doc13-15章68pptx.pptx13-15章习题docx.docx16-18章docx.docx16-18章解析docx.docx2024考研刷... 1231 0 24-08-19
发表我的评论
- 这篇文章还没有收到评论,赶紧来抢沙发吧~