没有监控过JVM内存的职场生涯,是不完美的

通过对堆和Metaspace的使用情况分析,可以看到对应内存空间的使用和增长情况,可进行合理调整和规划。

没有监控过JVM内存的职场生涯,是不完美的

点击右上角的“堆 dump”,会基于点击的时间节点生成dump文件。

没有监控过JVM内存的职场生涯,是不完美的

概要部分会显示生成dump文件的时间节点和存储路径。我们用来分析内存主要是在此页面中的“类”菜单内。

没有监控过JVM内存的职场生涯,是不完美的

进入可查看在堆中不同实例占用的内存大小。双击类名,即可进入查看“实例数”,也就是具体类的实例详情。

没有监控过JVM内存的职场生涯,是不完美的

而我们在内存分析时最重要的其实就是“类”的数量。在了解了上述的基本操作之后,我们就用一个实例来模拟分析一下内存溢出的场景吧。

内存溢出场景构建

========

先写一段代码,用来模拟内存溢出,也就是创建一个Map,然后向其中不断的新增对象。同时在程序处理的过程中让线程睡眠或死循环来方便通过VisualVM进行查看。

测试代码如下:

public class MemoryLeakTest {

/**

  • 声明缓存对象

*/

private static final Map<String, TestMemory> CACHE_MAP = new HashMap<>();

public static void main(String[] args) {

try {

//给打开visualVm时间

Thread.sleep(10000);

} catch (InterruptedException e) {

e.printStackTrace();

}

//循环添加对象到缓存

for (int i = 0; i < 1000000; i++) {

TestMemory t = new TestMemory();

CACHE_MAP.put(“key” + i, t);

}

System.out.println(“-------1------”);

//为dump出堆提供时间

try {

//给打开visualVm时间

Thread.sleep(10000);

} catch (InterruptedException e) {

e.printStackTrace();

}

for(int i=0; i<1000000;i++){

TestMemory t = new TestMemory();

CACHE_MAP.put(“key”+i,t);

}

}

}

TestMemory类代表生成中的业务类。

public class TestMemory {

}

为了让程序更快地达到内存的阈值,我们启动时可限制JVM的大小,这里设置为:

-Xms128m -Xmx128m

另外,为了分析堆的内存结构中每个区域(新生代、老年代)的内存使用情况,可在VisualVM的“工具”、“插件”中安装Visual GC插件。该插件的使用后续会看到效果。

没有监控过JVM内存的职场生涯,是不完美的

一切准备妥当,下面来进行验证。

内存溢出分析

======

下面我们就来启动程序,启动VisualVM来进行内存溢出的分析。

当程序执行的过程中,我们会发现“堆”内存会出现一个快速增加的曲线。

没有监控过JVM内存的职场生涯,是不完美的

这个过程中Metaspace也在随之增长。

打开Visual GC界面,我们会看到面试中被问过很多遍的堆内存结构:

没有监控过JVM内存的职场生涯,是不完美的

通过这张图,可以直观的看到堆内存中的老年代、新生代、Metaspace空间(JDK8),还有新生代中的Eden、S0(Survivor From)、S1(Survivor To),而且它们的分配比例也有一个比较直观的展示。通过这种形式,是不是可以更直观的学习堆内存结构呢?

这里Eden已经被填满、S0和S1为空,老年代也几乎被填满(因为垃圾收集无法清除持有引用的对象)。

没有监控过JVM内存的职场生涯,是不完美的

最重要的是你会发现针对老年代在20分钟内进行了3850次垃圾回收。也就是说已经触发了频繁的Full GC操作,而且内存并没有被释放掉。在生产系统中,当你看到系统在频繁的进行Full GC操作,那是JVM在释放一个很恐怖的信号了。

上面说了一些表象的内容,现在真正开进行内存分析了。回到上面提到的“监视”、“堆dump”、“类”中,可以看到下图:

没有监控过JVM内存的职场生涯,是不完美的

可以看到,堆中存在着100万个TestMemory对象。当你看到堆中有类似的大量的对象存在,你应该意识到此处可能有内存泄露。也就是大量的对象被创建,而没有被“顺利”回收。我们这里没被回收的原因是对象被放在了静态变量里面了。

上面已经提到,你还可以进一步双击对象名称,去查看对象的详细信息。

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

总结

总的来说,面试是有套路的,一面基础,二面架构,三面个人。

最后,小编这里收集整理了一些资料,其中包括面试题(含答案)、书籍、视频等。希望也能帮助想进大厂的朋友

三面蚂蚁金服成功拿到offer后,他说他累了

三面蚂蚁金服成功拿到offer后,他说他累了

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
,小编这里收集整理了一些资料,其中包括面试题(含答案)、书籍、视频等。希望也能帮助想进大厂的朋友**

[外链图片转存中…(img-Xntxhvnb-1713742182830)]

[外链图片转存中…(img-WyDpv7p3-1713742182830)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 26
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值