Linux 内存 占用较高问题排查

一 查看内存情况

#按 k 查看

free 

#按兆M查看

free -m

在这里插入图片描述

total:总计物理内存的大小。
used:已使用多大。
free:可用有多少。
Shared:多个进程共享的内存总额。
Buffers/cached:磁盘缓存的大小。
#所以空闲内存=free+buffers+cached=total-used
内存的使用情况

cat /proc/meminfo

查看进程的内存占用

pidstat -r -p 24427 1 5 

内存占用高的前20

ps aux | head -1;ps aux |grep -v PID |sort -rn -k +4 | head -20

动态查看内存占用

slabtop

二 问题定位

cached 占用过高问题
buffer,cached的作用:

 cached主要负责缓存文件使用, 日志文件过大造成cached区内存增大把内存占用完 .
 Free中的buffer和cache:(它们都是占用内存):
 buffer : 作为buffer cache的内存,是块设备(磁盘)的缓冲区,包括读、写磁盘
 cache: 作为page cache的内存, 文件系统的cache,包括读、写文件
 如果 cache 的值很大,说明cache住的文件数很多。

linux服务器会自动释放内存,保障系统运行,但只会释放够用的内存,而不会去释放更多的内存。

解决方法:
手动释放cached方法有三种(系统默认值是0,释放之后你需要再改回0值):
释放前最好sync一下,防止丢数据

sync 在启动机器或关机之前一定要运行sync命令。记住在任何情况下,慎重地执行sync命令决不会有任何坏处,sync命令强制把磁盘缓冲的所有数据写入磁盘

To free pagecache: #echo 1 > /proc/sys/vm/drop_caches

To free dentries and inodes: #echo 2 > /proc/sys/vm/drop_caches

To free pagecache, dentries and inodes: #echo 3 > /proc/sys/vm/drop_caches

#常用方法是

sync

echo 1 > /proc/sys/vm/drop_caches

#清除后要还原系统默认配置:

echo 0 > /proc/sys/vm/drop_caches

#查看设置

 sysctl -a | grep drop_caches

补充: echo 字符串 > 文件 就是把字符串内容从定向到文件中
在这里插入图片描述

这时查看 free 可以看到 cached 降低了很多

本文参照:https://www.cnblogs.com/ysgs1995/p/13873021.html

  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值