linux的斩杀线之OOM操控

什么是OOM

对于操作系统来说,为了维护自身的稳定,有一个"物理斩杀"的机制,即OOM机制。OOM会在操作系统的内存资源不足时,选择特定的进程直接斩杀(kill),以此来释放内存,保证系统可以正常运行。

OOM系统参数简单说明

  1. panic_on_oom
  • 修改位置:sysctl修改vm.panic_on_oom

  • 功能说明:

  • 0 :内存不足时,触发OOM Killer(默认值)

  • 1 :内存不足时,根据具体情况可能发生kernel panic,也可能触发OOM killer

  • 2 :内存不足时,强制触发系统panic,导致系统重启

  1. oom_kill_allocating_task
  • 修改位置:sysctl修改vm.oom_kill_allocating_task

  • 功能说明:

  • 0 :选择oom_score得分最高的进程(默认值)

  • 非0:选择触发OOM的进程

  1. oom_dump_tasks
  • 修改位置:sysctl修改vm.oom_dump_tasks

  • 功能说明:

  • 0 :OOM发生时不会打印相关信息

  • 非0:以下三种情况会调用dump_tasks打印系统中所有task的内存状况。(默认值1)

  • 由于OOM导致kernel panic。

  • 没有找到需要结束的进程。

  • 找到进程并将其结束的时候

  1. oom_score
  • 修改位置:echo 1000 > /proc/<pid>/oom_score_adj

  • 功能说明:

  • 0 :不调整oom_score(默认值)

  • 负值:在实际打分值上减去一个折扣(若设定成OOM_SCORE_ADJ_MIN或-1000,则表示禁止OOM killer结束该进程)

  • 正值:增加该进程的oom_score

  1. cgroup优先级配置

  2. cgroup的内存节点设置

OOM触发条件说明

  1. cgroup内存不足:

使用的内存超出了cgroup中memory.limit_in_bytes配置的大小

  • 示例:cgroup的limit_in_bytes设置80M,实际使用超过80M
  1. 父cgroup内存不足:

在子cgroup中内存仍然足够,但是父cgroup的内存不足,超过了内存限制(父进程的memory.limit_in_bytes)

  • 示例:父进程cgroup的limit_in_bytes设置80M,两个子进程的cgroup的limit_in_bytes分别设置50M
  1. 系统全局内存不足

方面由于OS的空闲内存不足,有程序一直在申请内存,另一方面也无法通过内存回收机制解决内存不足的问题,因此触发了OOM

  1. 内存节点(Node)的内存不足

在NUMA存储模式下,OS会存在多个内存节点,如果程序指定使用特定节点的内存,可能在OS内存充足的情况下触发OOM

  1. 其他可能原因

OS在内存分配的过程中,如果伙伴系统的内存不足,则系统会通过OOM Killer释放内存,并将内存提供至伙伴系统

解决方案

  1. 从业务进程排查,确认是否有内存泄漏,导致OOM。

  2. 排查cgroup limit_in_bytes配置是否与业务内存规划匹配,如需要调整,可以手动执行以下命令修改配置参数:

echo <value> > /sys/fs/cgroup/memory/<cgroup_name>/memory.limit_in_bytes

  1. 如果确认业务需要比较多的内存,建议升级弹性云服务器内存规格。

  2. 调整系统内核参数

总结

对于OOM,我们可以通过多个角度来实现细粒度的控制。

|--------------------------|------------------------------------------------------------------------------------|------------------------------------------------|
| 方式 | 说明 | 设置内容 |
| cgroup | cg组优先级设置,进程挂在组下受优先级影响 | cgroup的memory.use_priority_oom和memory.priority |
| cgroup | cg组内存绑定策略设置,进程挂载组下受内存绑定策略影响 | cgroup中的cpuset下的cpuset.mems |
| oom_score_adj | 进程得分调整接口,可以设置永不kill 或 靠影响得分间接影响oom顺序 | /proc/\<pid\>/oom_score_adj |
| memory policy | 内存绑定策略调整。对于"bind"或"interleave"策略,检查掩码与策略节点掩码是否存在交集。对于"perferred"或"local"策略,始终认为有交集 | numactl -m / set_memory_policy |
| oom_kill_allocating_task | 选择kill触发者,还是受害者 | vm.oom_kill_allocating_task |

相关推荐
CRUD酱1 天前
CentOS的yum仓库失效问题解决(换镜像源)
linux·运维·服务器·centos
zly35001 天前
VMware vCenter Converter Standalone 转换Linux系统,出现两个磁盘的处理
linux·运维·服务器
Albert Edison1 天前
【Python】函数
java·linux·python·pip
General_G1 天前
Linux中的信号
linux·运维·服务器
诸神缄默不语1 天前
当无法直接用apt instll时,Linux如何离线安装软件包(以make为例)
linux·运维·服务器
Sivan_Xin1 天前
拒绝 If-Else 屎山:利用适配器模式(Adapter)构建第三方登录的“防腐层”实战
linux·python·适配器模式
learning-striving1 天前
kali默认桌面Xfce切换为GNOME桌面
linux·运维·服务器·kali
源远流长jerry1 天前
dpdk之kni处理dns案例
linux·网络·网络协议·ubuntu·ip
黄昏晓x1 天前
Linux----进程控制
android·linux·运维
郝亚军1 天前
ubutnu 64位系统,需要安装的工具包
linux·运维·ubuntu