Linux程序异常退出提示out of memory
时间:2015-12-31 23:52 来源:linux.it.net.cn 作者:IT
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进程导致系统崩溃,所以出现内存资源不足时,建议优化各类程序,如优化的空间有限,建议提升系统内存。
(责任编辑:IT)
Linux上的程序会出现异常退出的情况,多数是因为系统内存不足造成的,Linux内存不足时通常会触发 Linux 内核里的 Out of Memory (OOM) killer,OOM killer 会杀掉内存占用最多的进程以腾出内存留给系统用,不致于让系统立刻崩溃。 如果检查相关的日志文件(/var/log/messages)就会看到下面类似的 Out of memory: Kill process 信息:
...
临时解决方法: 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进程导致系统崩溃,所以出现内存资源不足时,建议优化各类程序,如优化的空间有限,建议提升系统内存。
(责任编辑:IT) |