Linux内存[buff/cache]占用过高分析和优化

本文介绍了Linux系统中内存管理的问题现场分析,特别是针对页面缓存的管理与优化方法。通过监控系统负载和I/O情况,分析了导致内存占用过高的根本原因,并提供了具体的解决策略。

问题现场

查看系统内存的使用状态
linux-buff-free.jpg
监控报警可用内存空间不足,常规的解决方案如下:

  1. 增加内存(增加成本)
  2. 增加虚拟内存(影响性能)
  3. 定期清理缓存(echo 1 > /proc/sys/vm/drop_caches)

本文将介绍定期清除页面缓存,但是过会儿内存又被占满问题的分析。

问题分析

  1. 通过监控系统负载情况(vmstat 1),确定是页面缓存(cache项)占用量大,并且释放页面缓存后从块设备读入数据量(bi项)会马上增加。
    linux-buff-vmstat.jpg

  2. 通过监控io情况(iostat -x -k 1)也可以看出
    linux-buff-iostat.jpg

  3. 基于此可以猜测是有进程在频繁的读取文件导致,监视磁盘I/O使用状况(iotop -oP),释放页面缓存后有几个sed命令读取文件进程占用IO很高。
    linux-buff-iotop.jpg

  4. 至此结合业务分析是因为每分钟读取日志统计指标导致

扩展知识

/proc/meminfo

查看更详细的内存信息:
$ cat /proc/meminfo |grep -E "Buffer|Cache|Swap|Mem|Shmem|Slab|SReclaimable|SUnreclaim"
linux-buff-meminfo.jpg

  • MemFree:空闲的物理内存
  • MemAvailable:可用的物理内存,MemFree+Buffers+Cached
  • Buffers:(Buffer Cache)对磁盘块设备数据的缓存
  • Cached:(Page Cache)对文件系统上文件数据的缓存,MemFree+SReclaimable
  • SwapTotal:虚拟内存,利用磁盘空间虚拟出的一块逻辑内存
  • Slab:Linux内存管理机制
  • SReclaimable:Slab可回收部分
  • SUnreclaim:Slab不可回收部分
  • Shmem:进程间共同使用的共享内存

/proc/sys/vm/drop_caches

清除缓存策略:
1:清除page cache
2:清除slab分配器中的对象(包括目录项和inode)
3:清除page cache和slab分配器中的对象

参考

OOM killer及Overcommit
Linux buffer/cache 内存占用过高的原因以及解决办法
Linux查看Buffer&Cache被哪些进程占用

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值