Linux下的cache和buffer是物理内存分配给高速缓存,以保证系统运行的更快,使用free命令可以查看内存的使用情况,
此处的内存使用情况:第一行的free+buffer为物理内存分配出来,但是free和buffer还没有使用的大小。
第二行的-/+buffer/cache中的使用内存used为物理内存分配给buffer和cached的使用情况,free为真实的内存剩余大小。
总内存:memory=used+free=used1+free1=buffers+cached+used1+free
也就是说:free1=free+buffers+cache。
内存中的buffers和cached为内存使用的机制。
Buffers和cached:
Buffers(缓冲区)为还没有写入硬盘,cached(缓存)为已被从硬盘中读取和存入硬盘以备使用。
Linux内核中cache的实现:
Kmem_cache是Linux内核提供的快速内存缓冲接口,这些内存块要求是大小相同的,因为分配出的内存在接口师范时并不是真正释放,而是作为缓存保留,下一次请求分配时就可以直接使用,省去了各种内存块初始化或者释放的操作,因此分配速度很快,通常用于大数量的内存块儿分配情况,如:inode节点,skbuff头,netfilter的连接,可以通过/proc/slabinfo文件直接读取cache分配情况。
Kmem_cache在/proc/slabinfo中可以找到。
新的概念:
Page:Linux中,page是内核中内存基本管理单元,每个page的内存大小是固定的,对于x86来说,page是4k,slab则是kmem_cache的具体内存空间形式,根据cache的对象的大小,每个slab可以有1-32个page,如果把cache对象比一个page的空间还小,那么这个page对象会容纳多个对象以尽可能利用空间。
Kmem_cache数据结构并没有定义在.h的头文件。
相关阅读:
Buffer cache和page cache的区别 http://www.linuxidc.com/Linux/2013-01/78140.htm
Linux中Buffer cache性能问题一探究竟 http://www.linuxidc.com/Linux/2013-01/77573.htm