28

我目前遇到垃圾收集时间很长的问题。请参阅以下内容。我当前的设置是我正在使用 -Xms1g 和 -Xmx3g。我的应用程序使用的是 java 1.4.2。我没有设置任何垃圾收集标志。从外观上看,3gb 是不够的,我真的有很多对象要垃圾收集。

问题:

我应该改变我的垃圾收集算法吗?我应该用什么?是不是更好用-XX:+UseParallelGC or -XX:+UseConcMarkSweepGC

还是我应该使用这种组合

-XX:+UseParNewGC -XX:+UseConcMarkSweepGC

占用内存的主要是报告数据,而不是缓存数据。另外,机器有 16gb 内存,我计划将堆增加到 8gb。

这两个选项之间有什么区别,因为我仍然很难理解。机器有多个处理器。我最多可以承受 5 秒的打击,但 30 到 70 秒真的很难。

谢谢您的帮助。

  Line 151493: [14/Jan/2012:11:47:48] WARNING ( 8710): CORE3283: stderr: [GC 1632936K->1020739K(2050552K), 1.2462436 secs]
    Line 157710: [14/Jan/2012:11:53:38] WARNING ( 8710): CORE3283: stderr: [GC 1670531K->1058755K(2050552K), 1.1555375 secs]
    Line 163840: [14/Jan/2012:12:00:42] WARNING ( 8710): CORE3283: stderr: [GC 1708547K->1097282K(2050552K), 1.1503118 secs]
    Line 169811: [14/Jan/2012:12:08:02] WARNING ( 8710): CORE3283: stderr: [GC 1747074K->1133764K(2050552K), 1.1017273 secs]
    Line 175879: [14/Jan/2012:12:14:18] WARNING ( 8710): CORE3283: stderr: [GC 1783556K->1173103K(2050552K), 1.2060946 secs]
    Line 176606: [14/Jan/2012:12:15:42] WARNING ( 8710): CORE3283: stderr: [Full GC 1265571K->1124875K(2050552K), 25.0670316 secs]
    Line 184755: [14/Jan/2012:12:25:53] WARNING ( 8710): CORE3283: stderr: [GC 2007435K->1176457K(2784880K), 1.2483770 secs]
    Line 193087: [14/Jan/2012:12:37:09] WARNING ( 8710): CORE3283: stderr: [GC 2059017K->1224285K(2784880K), 1.4739291 secs]
    Line 201377: [14/Jan/2012:12:51:08] WARNING ( 8710): CORE3283: stderr: [Full GC 2106845K->1215242K(2784880K), 30.4016208 secs]


xaa:1: [11/Oct/2011:16:00:28] WARNING (17125): CORE3283: stderr: [Full GC 3114936K->2985477K(3114944K), 53.0468651 secs] --> garbage collection occurring too often as noticed in the time. garbage being collected is quite low and if you would notice is quite close the the heap size. during the 53 seconds, this is equivalent to a pause.
xaa:2087: [11/Oct/2011:16:01:35] WARNING (17125): CORE3283: stderr: [Full GC 3114943K->2991338K(3114944K), 58.3776291 secs]
xaa:3897: [11/Oct/2011:16:02:33] WARNING (17125): CORE3283: stderr: [Full GC 3114940K->2997077K(3114944K), 55.3197974 secs]
xaa:5597: [11/Oct/2011:16:03:00] WARNING (17125): CORE3283: stderr: [Full GC[Unloading class sun.reflect.GeneratedConstructorAccessor119]
xaa:7936: [11/Oct/2011:16:04:36] WARNING (17125): CORE3283: stderr: [Full GC 3114938K->3004947K(3114944K), 55.5269911 secs]
xaa:9070: [11/Oct/2011:16:05:53] WARNING (17125): CORE3283: stderr: [Full GC 3114937K->3012793K(3114944K), 70.6993328 secs]
4

4 回答 4

7

由于您有极长的 GC 暂停,因此认为更改 GC 算法不会有帮助。

请注意,您只有完整的收藏是非常可疑的。也许您需要增加年轻代和/或幸存者空间的大小。

也可以看看:

于 2012-01-25T16:01:10.353 回答
4

你的堆太小了。暂停是如此之大,因为它正忙于反复扫描整个堆,拼命寻找要收集的东西。

您需要执行以下一项或多项操作;

  • 查找并修复内存泄漏
  • 调整应用程序以使用更少的内存
  • 配置 JVM 是使用更大的堆

由于某种原因,您是否与 1.4.2 相关联?从那时起,GC 实现确实已经发展,所以如果可能的话,你应该考虑升级。我意识到这可能是一项艰巨的任务,但无论如何都值得考虑。

于 2012-01-25T16:19:35.910 回答
1

如果你的存活率很高,你的堆可能太大了。堆越大,JVM 在没有 GC 的情况下可以运行的时间越长,所以一旦它命中,它就有更多的东西可以移动。

于 2012-03-05T21:38:04.650 回答
1

步骤1:

  1. 确保您为应用程序设置了足够的内存。
  2. 确保您的应用程序中没有内存泄漏。Eclipse Memory Analyzer Toolvisualvm将帮助您识别应用程序中的泄漏。

第2步:

如果您在第 1 步中没有关于内存泄漏的任何问题,请参阅“Java 垃圾收集器”部分和gctuning文章中特定垃圾收集算法的用例的 Oracle 文档页面。

由于您已决定配置更大的堆 (>= 8 GB),因此 G1GC 应该适合您。请参阅有关微调关键参数的相关 SE 问题:

G1 上的 Java 7 (JDK 7) 垃圾收集和文档

于 2015-12-09T18:02:21.140 回答