【发布时间】:2013-09-02 20:06:23
【问题描述】:
我想在 JVM 崩溃时收集堆转储
所以我写了一个简单的代码
public class Test {
private String name;
public Test(String name) {
this.name = name;
}
public void execute() {
Map<String,String> randomData = new HashMap<String,String>();
for(int i=0;i<1000000000;i++) {
randomData.put("Key:" + i,"Value:" + i);
}
}
public void addData() {
}
public static void main(String args[]) {
String myName = "Aniket";
Test tStart = new Test(myName);
tStart.execute();
}
}
我按如下方式运行它
[aniket@localhost Desktop]$ java -cp . -Xms2m -Xmx2m Test
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at Test.execute(Test.java:15)
at Test.main(Test.java:25)
我得到了我想要的 OutOfMemoryError,但工作目录中没有堆转储(如我所期望的 hs_err_pidXXXX.log)。我错过了什么?如何获得堆转储?
更新:
我试过-XX:ErrorFile=. 还是没用。如果上述方法不是获取堆转储(Crash JVM)的方法,我该如何让我的 JVM 崩溃以获取这些日志?
【问题讨论】:
-
hs_err_pidXXXX.log仅在 JVM 崩溃时创建,而不是应用程序。 -
您可以使用 eclipse 记录堆转储查看此处了解详细信息stackoverflow.com/questions/837351/…
-
那我该如何让我的 JVM 崩溃呢?我需要生成那个文件。
标签: java jvm heap-dump jvm-crash