首页 > 代码库 > Linux内核管理--内存(一)
Linux内核管理--内存(一)
1)Linux把空闲的物理内存划出一部分用作buffer,cache
2)buffer cache是高速缓存环从,目的是为了解决磁盘读取速度远小于内存这个问题,cpu从内存直接读取最快;
3)但是物理内存有限,不可能所有数据都在物理内存,swap交换分区就出现了,内核会根据“”最近经常使用“”算法,把不经常使用的内存数据交换到swap;
4)有时可以发现物理内存充足,swap也使用了很多也是正常的,因为linux内存交换是不时在进行的,一个占用内存资源很大的程序开始时,会把不经常用的数据放到swap,这个程序结束时,资源释放了一些,但是交换到swap的也不会马上回到物理内存,除非有必要。
5)swap中的数据如果需要调用,会被重新交换进物理内存,如果这时候物理内存没有空间,它们会被退回到swap, 几次之后可能swap和物理内存都没有空间存储这些页面,系统就会假死。
6)free项看内存时,shared表示多个进程共享的内存资源,自己free和used时不能忽略buffer cache,真正的free数量是used+buffer/cached, 其实free命令输出的数值一个是内核视角(mem一行),一个是用户视角(加上buffer/cache)。
7)buffer是写操作缓冲块设备的,cache是记忆的文件。
Linux内核管理--内存(一)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。