博客
关于我
Linux 3.x 内核学习笔记——页面的周转
阅读量:546 次
发布时间:2019-03-09

本文共 584 字,大约阅读时间需要 1 分钟。

页面周转

本文以Linux-3.11.0为例,探讨内核中页面状态及管理机制。

内核管理内存的物理页面,这些页面在运行过程中可处于五种状态。初始阶段,系统将部分页面标记为freeze状态,这些页面无法被分配或释放,用于内核映像和硬件需求等保留地址。初始化完成后,这些页面仍然保持在freeze状态。

系统分为七种流程管理页面分配和释放:初始释放、冷热队列管理、页面合并、页面迁移、单页分配、多页分配、区域管理等。每个cpu有冷热队列,用于快速获取或释放页面;每个zone有11个免费区域队列,管理不同大小的物理页面。

普通页面(如vmalloc/kmalloc)采用简单分配和释放流程,而对Lru页面,内核采取更复杂的交换机制。内核为每个node创建kswapd进程,周期性地扫描Active Anon队列,将页面移到Inactive Anon或直接解除映射。

页面映射pte表项的访问标志决定了页面的状态。若标志为0,页面可被解除映射并换出;若标志为1,页面需重新访问后才能解除映射。用户可通过mlockmlockall固定页面,防止换出;munlockmunlockall则恢复页面可换性。

内核通过精细的页面管理机制,确保内存资源的高效利用,同时在内存紧张时优先回收活跃页面,减少系统性能损失。这种机制不仅提升了系统性能,还为用户提供了更高级别的内存管理控制。

转载地址:http://skriz.baihongyu.com/

你可能感兴趣的文章
PL/SQL Developer中文版下载以及使用图解(绿色版)
查看>>
pl/sql developer乱码,日期格式等问题解决
查看>>
PL/SQL 中的if elsif 练习
查看>>
PL/SQL 存储函数和过程
查看>>
query简单入门到精通细节 - (六)Jquery效果之“淡入与淡出”
查看>>
PL/SQL提示“ORA-01722:无效数字,将无效数字查找出来
查看>>
PL/sql语法单元
查看>>
PL/SQL连接远程服务器数据库,出现ORA-12154: TNS: 无法解析指定的连接标识符。
查看>>
pl/sql锁
查看>>
PL2303 Windows 10 驱动项目常见问题解决方案
查看>>
QueryPerformanceCounter与QueryPerformanceFrequency
查看>>
Plaid.com的监控系统如何实现与9600多家金融机构的集成
查看>>
Plain Stock Prediction:基于RNN的股票价格预测工具
查看>>
platform_driver与file_operations两种方法开发led驱动
查看>>
PlatON共识方案详解:应用CBFT共识协议,提高共识效率
查看>>
QueryDict和模型表知识补充
查看>>
Querybase 使用与安装教程
查看>>
Playwright与Selenium的对比:谁是更适合你的自动化测试工具?
查看>>
quarz设置定时器任务的有效时间段_定时器?你知道有几种实现方式吗?
查看>>
PLC、DCS、SCADA的选型
查看>>