一般来说,当系统负载过重,内存耗用过多时,oom-killer 开始杀进程,即使服务器配置了6G以上的内存,在许多报告中人们为可用内存充裕而被杀进程感到困惑。
对于32bit的内存管理结构如下:
# DMA: 0x00000000 - 0x00999999 (0 - 16 MB)
# LowMem: 0x01000000 - 0x037999999 (16 - 896 MB) - size: 880MB
# HighMem: 0x038000000 -
如果系统还有很多剩余内存,依然出现OOM,那么问题是 low memory 用尽。
引用 TOM 所说:“内核使用 low memory 来跟踪分配的所有内存,因此16G的内存将比4G的内存使用更多的 low memory,也许多达4倍。这种额外的压力发生的时刻
可以用两条命令查看 low memory 和 high memory:
egrep 'High|Low' /proc/meminfo
free -lm
当 low memory 被耗尽的时候,high memory 的多少已经不重要,oom-killer 会开始杀进程已保证系统本身的存活。
有两个解决方案。
1、升级至64位的 Linux 版本,这是最好的解决方案。
2、如果是32位的 Linux 版本,最好的解决办法就是应用 hugemem kernel 并重启(其实是一个rpm包,厂家提供给我的是 kernel-hugemem-2.4.21-50.EL.i686.rpm )
针对32位的 Linux 版本,还有一个解决方法设置 /proc/sys/vm/lower_zone_protection 值为250或更高。
可以这样设置
# cat /proc/sys/vm/lower_zone_protection
# echo "250" > /proc/sys/vm/lower_zone_protection
设置成启动加载,在 /etc/sysctl.conf 中加入
vm.lower_zone_protection = 250
最无力的解决办法,就是禁用 oom-killer ,这可能会导致系统挂起,所以要慎重使用。
检查 oom-killer 状态:
# cat /proc/sys/vm/oom-kill
使 oom-killer 关闭/开启:
# echo "0" > /proc/sys/vm/oom-kill
# echo "1" > /proc/sys/vm/oom-kill
使设置启动时生效,需要在 /etc/sysctl.conf 中加入
vm.oom-kill = 0
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/14130873/viewspace-719463/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/14130873/viewspace-719463/