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是记忆的文件。
这个对buffer cache解释很详细
这篇对linux内存计算很详细。
page table工作原理