在 Linux 中,如果系统的内存或交换空间耗尽,内核的 OOM (Out-Of-Memory) 杀手会触发,将杀掉一些高内存使用的进程以释放内存。这种情况可以在系统日志中查看。以下是具体的查看步骤:
/var/log/messages
或 /var/log/syslog
在多数 Linux 系统中,内核和系统的日志记录在 /var/log/messages
或 /var/log/syslog
文件中。在这些文件中可以查找是否有 OOM 相关的记录。
grep
搜索 OOM 日志grep -i "killed process" /var/log/messages
或
grep -i "killed process" /var/log/syslog
dmesg
输出内核日志中也会记录 OOM 事件,通常可以用 dmesg
来查看。查找与 OOM 相关的记录:
dmesg | grep -i "killed process"
OOM 日志通常包含类似以下的记录:
[ pid ] Out of memory: Kill process 12345 (process_name) score 550 or sacrifice child
Killed process 12345 (process_name) total-vm: 2048000kB, anon-rss: 1024000kB, file-rss: 10240kB
/var/log/kern.log
部分系统中,内核相关日志也会记录在 /var/log/kern.log
文件中。在这里也可以找到被 OOM 杀手终止的进程记录。
grep -i "Out of memory" /var/log/kern.log
journalctl
查看 OOM 日志(systemd 系统)如果系统使用 systemd,日志记录通过 journalctl
命令可以查看。可以过滤 kernel
日志查找 OOM 记录:
journalctl -k | grep -i "Out of memory"
或直接过滤内存被杀事件:
journalctl | grep -i "killed process"
oom_score
和 oom_score_adj
可以在 /proc/<PID>/oom_score
和 /proc/<PID>/oom_score_adj
中查看进程的 OOM 评分。这些评分越高的进程越有可能被杀死。
其中:
oom_score
:系统自动根据进程内存占用和系统负载计算的分数。oom_score_adj
:可以手动调节进程的 OOM 分数,范围是 -1000(最不可能被杀)到 1000(最可能被杀)。因篇幅问题不能全部显示,请点此查看更多更全内容
Copyright © 2019- igbc.cn 版权所有 湘ICP备2023023988号-5
违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务