1

我有一个在 jboss5 下运行的应用程序。它有一个用户登录端以及后台石英作业。一项后台作业进行了一次肥皂调用并拉下一个大对象进行解析。它使用了大量的内存。

当我收到这样的 OOM 异常时,我看到了一种模式:

2013-06-04 21:44:36,855 ERROR [STDERR] (QuartzScheduler_Scheduler-NON_CLUSTERED_MisfireHandler) java.lang.OutOfMemoryError: Java heap space
2013-06-04 21:44:36,855 ERROR [STDERR] (http-0.0.0.0-80-9) Exception in thread "http-0.0.0.0-80-9" 
2013-06-04 21:44:36,855 ERROR [STDERR] (http-0.0.0.0-80-9) java.lang.OutOfMemoryError: Java heap space
2013-06-04 21:44:36,855 ERROR [STDERR] (Session Monitor) Exception in thread "Session Monitor" 
2013-06-04 21:44:36,855 ERROR [STDERR] (Monitor Runner) java.lang.OutOfMemoryError: Java heap space
2013-06-04 21:44:36,855 ERROR [STDERR] (Monitor Runner)     at java.util.Arrays.copyOf(Arrays.java:2219)
2013-06-04 21:44:36,855 ERROR [STDERR] (Monitor Runner)     at java.util.ArrayList.toArray(ArrayList.java:329)
2013-06-04 21:44:36,855 ERROR [STDERR] (Monitor Runner)     at java.util.ArrayList.<init>(ArrayList.java:151)
2013-06-04 21:44:36,855 ERROR [STDERR] (Monitor Runner)     at com.icesoft.util.MonitorRunner$1.run(MonitorRunner.java:54)

该作业每晚运行。当几天没有人使用UI时,我会在几天后得到OOM。但是当人们每天使用 UI 应用程序时,我可以使用一个多月或更长时间,而不会出现 OOM 问题。

使用应用程序时似乎发生了一些好事,但我不知道是什么。有谁知道从哪里开始寻找和尝试什么?

我们正在使用 jdk 1.7.0.11 和 javaopts

set "JAVA_OPTS=-Xrs -Xms256M -Xmx4096M -XX:MaxPermSize=256m -XX:+CMSClassUnloadingEnabled -XX:+UseConcMarkSweepGC "

谢谢,

吉姆

4

1 回答 1

1

使用-XX:+HeapDumpOnOutOfMemoryErrorJVM 参数,然后在 MAT 中打开 Heap Dump。MAT 会向您展示 OOM 的嫌疑人,您甚至可以自己遍历堆并确定哪些对象占据了堆的大部分。这样你就可以很容易地找到问题的罪魁祸首。

此外,这将有助于启用 GC 日志记录,以便您可以查看是否存在导致 OOM 的任何模式。

于 2013-06-26T04:28:03.757 回答