我的第一个OOM程序-阿里云开发者社区

开发者社区> 开发与运维> 正文

我的第一个OOM程序

简介: 个人博客http://www.lixiang.red/tech/java/2018/02/07/first-oom-java.html 欢迎点击,更多好技术好文在等着您! OOM解释 oom全称是 out of memory,就是堆内存溢出。

个人博客
http://www.lixiang.red/tech/java/2018/02/07/first-oom-java.html
欢迎点击,更多好技术好文在等着您!

OOM解释

oom全称是 out of memory,就是堆内存溢出。堆是JAVA虚拟机所管理的内存中最大的一块,也是所有线程共享的内存区域。

思路

  1. 既然是堆内存溢出,那就要往堆里面不断的塞东西。
  2. 给JAVA命令加上参数,把堆内存给限制下,这样能快速看到效果
  3. 通过jvisualvm看内存空间的变化

代码展示

我们将jvm参数做了如下设置

-Xms10m -Xmx10m

如下图通过man java 可以看到

-Xms: 初始化的堆大小。

-Xmx: 堆的最大内存。在本程序中将两者都初始化为10m

img_acee4691d97453af4f4b335abcde61de.jpe
man java
List<Object> oomObjects = new ArrayList<>();
while (true){
       oomObjects.add(new Object());
}

运行效果

img_70f02e0f8212b5036d25a0e0c830c6b9.jpe
OOM

结果分析

代码非常简单,我们初始化了一个List , 然后死循环向里面添加数据。然后就可以看到控制台在报OOM的错误。

我们用jvisualvm 看一看堆内存的情况。为了有时间打开visualvm , 加了一行线程休眠的代码Thread.sleep(100000)主线程休眠10s。通过下图可以看到在休眠10s 之后,堆内存瞬间就满了,程序也随之停止。

img_36f17a9e82699e51c1f4ea3105f1d5ce.jpe
jvm-heap

注:欢迎扫描下方二维码关注我哦

img_207e97637b7b73cfbfea3051281f9c7b.jpe
image

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
开发与运维
使用钉钉扫一扫加入圈子
+ 订阅

集结各类场景实战经验,助你开发运维畅行无忧

其他文章