赞
踩
说明:docker-compose up时,报了某Container exited with code 137… 我怀疑该容器被Linux进行OOMKille了
服务器上发包,构建完镜像执行Up的时候,给我提示了个:Container exited with code 137 。
这又是靓女落泪的一小会儿啊…
不过,看提示code 137,猜测是服务器内存不足,直接被Linux OOM killer(Out-Of-Memory killer)了。
获取镜像的元数据:docker inspect ContainerId
查看镜像的元数据,State中有个OOMKilled属性,为true则表示容器收到了SIGKILL信号,进程被杀掉了。
OOM全称 Out-of-Memory,是指操作系统的可用内存已经不足,且无法再分配新的内存出来给进程使用,导致系统无法继续工作。若不紧急处理,将会导致整个系统崩溃,所有进程均被杀死。
因此Linux OS为了保证内核系统层面的稳定运行,会根据一定算法规则,选出最优先占内存空间最大的进程进行杀死,进而释放出较多的内存空间,使系统程序继续稳定运行。这个机制就是OOM Killer机制。
楼主遇到的是这种情况,所以释放了内存。再重新跑就好了。
查看存储:docker system df
删除所有unused镜像:docker system prune -a
当然还有一种情况是:还有内存,但oom-killer依旧把进程杀死了。
这种情况是low memory耗尽,内核使用low memory来跟踪所有的内存分配。如果low memory耗尽,不管high memory剩多少,oom-killer都会杀死进程,以保持系统的正常运行。
可参考:https://developer.aliyun.com/article/513783
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。