Linux内存buffers,Linux下cache和buffer的使用情况

Linux下的cache和buffer是物理内存分配给高速缓存,以保证系统运行的更快,使用free命令可以查看内存的使用情况,

aa1b3380390700a0a7f476c161963d2e.png

此处的内存使用情况:第一行的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中可以找到。

dad430a53f1dcbb617ca1d56cabb51a9.png

新的概念:

Page:Linux中,page是内核中内存基本管理单元,每个page的内存大小是固定的,对于x86来说,page是4k,slab则是kmem_cache的具体内存空间形式,根据cache的对象的大小,每个slab可以有1-32个page,如果把cache对象比一个page的空间还小,那么这个page对象会容纳多个对象以尽可能利用空间。

Kmem_cache数据结构并没有定义在.h的头文件。

相关阅读:

0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值