首页 > 文档
为何MC能长期维持高性能读写
- 2024-05-30
- 1045 ℃
内存管理 slab 机制
讲完淘汰策略,我们接下来学习内存管理 slab 机制。
Mc 内存分配采用 slab 机制,slab 机制可以规避内存碎片,是 Mc 能持续高性能进行数据读写的关键。
slabclass
Mc 的 slab 机制是通过 slabclass 来进行运作的,如下图所示。Mc 在启动时,会构建长度为 64 的 slabclass 数组,其中 0 号 slabclass 用于 slab 的重新分配,1~63 号 slabclass 存储数据 Item。存储数据的每个 slabclass,都会记录本 slabclass 的 chunk size,同时不同 slabclass 的 chunk size 会按递增因子增加,最后一个 slabclass(即 63 号 slabclass)的 chunk size 会直接设为最大的 chunk size,默认是 0.5MB。每个 slabclass 在没有空闲的 chunk 时,Mc 就会为其分配一个默认大小为 1MB 的 slab,同时按照本 slabclass 的 chunk size 进行拆分,这些分拆出来的 chunk 会按 Item 结构体进行初始化,然后记录到 slabclass 的 freelist 链表中。当有 key/value 要存储在本 slabclass 时,就从 freelist 分配一个 Item,供其使用。同时,如果 Item 过期了,或被 flush_all 失效了,或在内存不够时被强项剔除了,也会在适当时刻,重新被回收到 freelist,以供后续分配使用。
下一篇:系统稳定,如何监控和保护进程安全
相关内容
考研数学历年真题及解析...
2012英语专业教师招聘试题
Linux命令速查手册
LWW解剖学精要图谱-- 胸...
2023法硕考研共享资料
口腔执业医师(2018)-基...
英二阅读真题精讲_陈志超
Java加密与解密的艺术
-
教师资格证考试作文【模板、范例、素材】
2024-08-19 1109
-
教师资格证考试--2019真题
2024-08-19 1001
-
奈特骨科疾病彩色图谱
2024-06-18 1154
-
2012政治,思想品德专业教师招聘试题
2024-08-20 1390
-
Java案例开发
2024-05-28 1205
-
Node.js开发指南
2024-05-24 1277
-
普通话水平测试提升指导视频及训练音频
2024-08-20 1058
-
奈特药理学彩色图谱
2024-06-18 1397
-
Backbone.js 入门实战 WEB端MVC框架开发单页应用实战
2024-05-28 1072
-
考研英语恋词30单元视频课学霸笔记
2024-08-19 1316
文章评论 (0)
- 这篇文章还没有收到评论,赶紧来抢沙发吧~


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