[心缘地方]同学录
首页 | 功能说明 | 站长通知 | 最近更新 | 编码查看转换 | 代码下载 | 常见问题及讨论 | 《深入解析ASP核心技术》 | 王小鸭自动发工资条VBA版
登录系统:用户名: 密码: 如果要讨论问题,请先注册。

[转帖]Linux进程被杀掉(OOM killer),查看系统日志

上一篇:[备忘]soapconnection的call设置timeout
下一篇:[GDS]WPNCS和WPNCB的区别

添加日期:2020/3/3 6:54:16 快速返回   返回列表 阅读1661次
原文:https://www.cnblogs.com/duanxz/p/10185946.html

基本概念:

Linux 内核有个机制叫OOM killer(Out Of Memory killer),该机制会监控那些占用内存过大,尤其是瞬间占用内存很快的进程,然后防止内存耗尽而自动把该进程杀掉。内核检测到系统内存不足、挑选并杀掉某个进程的过程可以参考内核源代码linux/mm/oom_kill.c,当系统内存不足的时候,out_of_memory()被触发,然后调用select_bad_process()选择一个”bad”进程杀掉。如何判断和选择一个”bad进程呢?linux选择”bad”进程是通过调用oom_badness(),挑选的算法和想法都很简单很朴实:最bad的那个进程就是那个最占用内存的进程。

如何查看:

(1)
grep "Out of memory" /var/log/messages
结果:
Mar  3 00:31:02 fx-0009 kernel: Out of memory: Kill process 15644 (mongod) score 858 or sacrifice child

(2)
运行egrep -i -r 'killed process' /var/log命令,结果如下:
/var/log/messages:Mar  3 00:31:02 fx-0009 kernel: Killed process 15644 (mongod) total-vm:8062428kB, anon-rss:7073148kB, file-rss:0kB, shmem-rss:0kB
(3)
也可运行dmesg命令,结果如下:
 

评论 COMMENTS
没有评论 No Comments.

添加评论 Add new comment.
昵称 Name:
评论内容 Comment:
验证码(不区分大小写)
Validation Code:
(not case sensitive)
看不清?点这里换一张!(Change it here!)
 
评论由管理员查看后才能显示。the comment will be showed after it is checked by admin.
CopyRight © 心缘地方 2005-2999. All Rights Reserved