上周由于工作原因,公司安排写单元测试,开始都很顺利,但是随着写的测试案例越来越多,项目单元测试运行就特别卡,极端情况下内存溢出,因此进行了排查
首先内存溢出问题,首先能想到的导致内存溢出的原因
代码问题...jvm配置
jmap -heap pid
可以清晰看到内存存是512M,新生代和老年代基本都满了,为了更好的看效果,当时我还用了jdk自带的工具Jconsole,这个工具非常直观,如下图,
看到这里时候...,内存回收不了多少内存,导致的内存溢出,
但是当时让本人疑惑的是,我的配置和别的项目一样呀,都是从别人那里复制过来的,然后我对比了一下,果然是我的Jvm配置有问题,根本就没有配置JVM参数,然后查了一下...,少了设置堆内存大小
maxHeapSize="2G"
然后设置之后,重新运行了一下单元测试,果然效果明显,不再发生内存溢出,也不是卡的一动不动了,然后我们又观察了一下内存情况,如下图
基本都是新生代来回进行复制进行垃圾回收...dump文件打印出来,尝试了各种办法,都没有办法打印出来,然后放弃了,设置jvm参数也是不起作用,研究了很长时间,谁知道配置错了文件
最终再把排查使用到的命令也分享一下,也是非常有用的命令
jstack