BufferCache的简单理解
对于磁盘和文件系统来讲
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,于是产生杀进程的现象。
本文来自博客园,作者:StepForwards,转载请注明原文链接:https://www.cnblogs.com/forwards/p/17577930.html