操作指南

最佳实践

故障处理

API 文档

文档捉虫大赛火热进行中,好礼多多> HOT
文档中心 > 云服务器 > 故障处理 > Linux 实例内存相关故障 > 实例内存未耗尽时触发 Out Of Memory

现象描述

Linux 云服务器在内存使用率未占满的情况下触发了 OOM(Out Of Memory)。如下图所示:

可能原因

可能原因 处理措施
内存使用率过高 检查内存使用率是否过高
进程数超限 检查进程数是否超限
系统可用内存低于 min_free_kbytes 值 检查系统可用内存是否低于 min_free_kbytes 值

故障处理

检查内存使用率是否过高

参见 内存使用率过高问题处理 ,查看实例是否内存使用率过高。若实例内存使用率正常,请 检查进程数是否超限

检查进程数是否超限

  1. 参见 日志报错 fork:Cannot allocate memory,核实进程数是否超限。若总进程数未超限,则执行下一步。
  2. 登录云服务器,执行以下命令查看 min_free_kbytes 值。
    sysctl -a | grep min_free
    min_free_kbytes 值单位为 kbytes,下图所示 min_free_kbytes = 1024000 即为1GB。
  3. 执行以下命令,使用 VIM 编辑器打开 /etc/sysctl.conf 配置文件。
    vim /etc/sysctl.conf
  4. i 进入编辑模式,修改 vm.min_free_kbytes 配置项。若该配置项不存在,则直接在配置文件中增加即可。
    说明

    建议修改 vm.min_free_kbytes 值为不超过总内存的1%即可。

  5. Esc 并输入 :wq 后,按 Enter 保存并退出 VIM 编辑器。
  6. 执行以下命令,使配置生效即可。
    sysctl -p

检查系统可用内存是否低于 min_free_kbytes 值

可能是由系统可用内存低于 min_free_kbytes 值导致。min_free_kbytes 值表示强制 Linux 系统最低保留的空闲内存(Kbytes),如果系统可用内存低于设定的 min_free_kbytes 值,则默认系统启动 oom-killer 或强制重启。具体行为由内核参数 vm.panic_on_oom 值决定:

  • vm.panic_on_oom=0,则系统会提示 OOM,并启动 oom-killer 杀掉占用最高内存的进程。
  • vm.panic_on_oom =1,则系统会自动重启。
目录