BufferCache的简单理解
  LEe7oAzCxFwr 2023年11月01日 58 0

对于磁盘和文件系统来讲
Buffer对应磁盘数据的缓存,用于读或写。
Cache对应文件数据的页缓存,用于读或写。

Buffer可以用来聚合多个写操作,Cache则可以理解为预读操作,文件系统通过这两种方式提升磁盘IO性能。

对于网络协议来讲
只有Buffer的概念,该Buffer对应数据的收发缓冲区。

对于cpu来讲
Cache的概念更多,主要用于CPU与内存的读写。其存在于CPU硬件中。

Buffer,Cache回收方式(网络协议部分不会参与该过程)

  • 自动回收,内存将要耗尽时触发
    比如到达高水位 /proc/sys/vm/min_free_kbytes 最小剩余大小
  • 手动回收 /proc/sys/vm/drop_caches
    echo 1 清楚page cache
    echo 2 回收slab分配器中的对象
    echo 3 包含1和2

Buffer, Cache回收的代价
Buffer写缓存不能直接删除,必须落盘数据一致,方可删除,因此清缓存时可能会存在大量IO,降低系统性能。
tmpfs、map、shmget中的缓存以及dirty pages 和 slab 中不可回收缓存,无法被自动回收。

交换分区
vm.swappiness控制页面交换的倾向程度

Buffer,Cache 较高通常属于正常现象,可能存在大量的文件读写,导致占用大量内存,但此时还未触发高水位回收机制,当应用程序申请大量内存时,可能会直接触发了OOM,于是产生杀进程的现象。

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月08日 0

暂无评论

推荐阅读
  kZLEadpmxZsY   2024年05月17日   31   0   0 Linux
  kZLEadpmxZsY   2024年05月17日   43   0   0 Linux
  4hf9DKAg5W6h   2024年05月17日   43   0   0 Linux
  2xk0JyO908yA   2024年05月17日   60   0   0 Linux
  tAaiqedz71Vf   2024年05月17日   57   0   0 Linux
  2sqDzWaoi9Ck   2024年05月17日   51   0   0 Linux
LVM
  XWcNkifzer3j   2024年05月20日   51   0   0 Linux
LEe7oAzCxFwr