Linux上的程序会出现异常退出的情况,退出的原因多数是因为系统内存不足,Linux内存不足通常会触发 Linux 内核里的 Out of Memory (OOM) killer,OOM killer 会杀掉内存占用最多的进程以腾出内存留给系统用,这样系统不致于立刻崩溃。
如果检查相关的日志文件(/var/log/messages)就会看到下面类似的 Out of memory: Kill process 信息:
...
Out of memory: Kill process 9682 (mysqld) score 9 or sacrifice child
Killed process 9682, UID 27, (mysqld) total-vm:47388kB, anon-rss:3744kB, file-rss:80kB
httpd invoked oom-killer: gfp_mask=0x201da, order=0, oom_adj=0, oom_score_adj=0
httpd cpuset=/ mems_allowed=0
Pid: 8911, comm: httpd Not tainted 2.6.32-279.1.1.el6.i686 #1
...
临时解决方法:
1.关闭oom-killer
cat /proc/sys/vm/oom-kill
echo "0" > /proc/sys/vm/oom-kill
vi /etc/sysctl.conf
vm.oom-kill = 0
2.修改该进程的OOM分数
echo -17 > /proc/PID/oom_adj
PID为不想被Kill的进程的进程ID,这样 OOM kill会跳过这个进程
3.或清空cache ,暂时释放内存
echo 3 > /proc/sys/vm/drop_caches
修改oom-killer的配置可能会在内存不足时无法kill进程导致系统崩溃,所以出现内存资源不足时,建议优化各类程序,如优化的空间有限,建议提升系统内存。