linux中buff/cache占用高

1. 现象

使用free -h查看内存情况时,发现buff/cache占比很高,使用top未发现有占用内存过高的进程。

在这里插入图片描述

2.解决

buff/cache一般用于磁盘或文件的存写,一些shared memory 也会放在这里,一般情况下大部分都是可以回收的。当出现不可回收时候,我们可以在/proc/sys/vm/drop_caches中查看缓存的内容,并可以使用手动回收,具体命令如下:

# 清除pagecache。
echo 1 > /proc/sys/vm/drop_caches
# 清除回收slab分配器中的对象(包括目录项缓存和inode缓存)。slab分配器是内核中管理内存的一种机制,其中很多缓存数据实现都是用的pagecache。
echo 2 > /proc/sys/vm/drop_caches
# 清除pagecache和slab分配器中的缓存对象。
echo 3 > /proc/sys/vm/drop_caches

使用主动去清理的话,如果内存中有一些没有落盘的数据,会在这个时候去写回。

你可能感兴趣的:(linux,linux,缓存,运维)