机器内存耗尽了?

解Bug之路

共 736字,需浏览 2分钟

 ·

2021-03-31 13:34

今天发现一些应用所在的机器其JVM只占了总共8G中2G的空间。Page cache也只占了1个G,但是free -g出来内存确已耗尽:

free -g
total used free shared buffers cached
Mem: 7 7 0 0 0 1

这个看上去很吓人。遇到这种情况,我们先cat /proc/meminfo看下具体的内存占用情况

cat /proc/meminfo
MemTotal: 8123456KB (8G)
......
Slab: 3671234KB (3.6G)
SReclaimable: 351234 (3.5G)

我们可以看到有将近3.6G被耗尽在Slab这一项里面,紧接着下面一项SReclaimable,表示这3.6个G中可回收的为3.5G。而这部分都统计在used里面,所以看上去吓人。

什么导致了slab过高

我们可以slabtop一下

slabtop
3123456K(3.1G) dentry

发现是目录项导致。这可能是内核访问了一个拥有特别多文件的文件夹导致。不过由于可回收,所以我们不用太担心。

手动清理

我们可以通过

echo 2 > /proc/sys/vm/drop_caches

手动清理可回收的slab内存。不过,清理当时,会对上面跑的应用有一定的影响。最好先下流量再做操作。

代码写累了?吃点坚果爽一爽。


浏览 13
点赞
评论
收藏
分享

手机扫一扫分享

举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

举报