有没有办法在Java中安排完整的垃圾收集?

时间:2014-01-02 22:38:40

标签: java garbage-collection

我有一个24x6计划运行的应用程序。目前,在运行几天后,会自动执行Full GC - 通常在一天的繁忙时段执行,这会对用户响应时间产生负面影响。

我想做的是强制使用全GC - 可能在每晚的午夜,在非常低的使用时间内 - 以防止它在白天发生。我已经尝试过System.gc(),但它似乎并不能保证何时会发生Full GC,或者即使它会发生。有没有办法做到这一点?

版本信息:

Java(TM)SE运行时环境(版本1.6.0_11-b03)
Java HotSpot(TM)服务器VM(版本11.0-b16,混合模式)

另外 -

  • 小型GC正在运行,大约每10-15秒。但这些都没有释放足够的RAM来让应用程序整整一周。当Full GC确实发生时,将释放近50%的堆。
  • 关于上述内容,调用System.gc()似乎并不意味着任何下一个GC都将具有释放那些大量内存所需的Full格式。是的,它已启用(或未启用,具体取决于您阅读-XX选项的方式)。
  • 我已经玩了几个CMS GC设置,这有很大帮助,但没有解决问题。最初它每周投掷两次到三次OOM。
  • 我想停止无限循环:
    • 不断添加到堆空间 - 这只能持续这么久
    • 不断调整和测试GC设置 - 它已经超过了收益递减点
  • 我不想把它当成NT机器,每晚都会反弹。整个晚上都有活跃的用户会话,弹出应用程序意味着会丢失会话数据。

更具体地说,我正在寻找一种技术来确保完整GC的发生,而不是一个简单的方法/函数来调用它。

目前,我正在考虑修改CMS使用的百分比阈值,以确定何时需要完整GC。

感谢您的帮助。

4 个答案:

答案 0 :(得分:15)

jmap -histo:live <PID>将强制Full GC作为查找所有活动对象的“副作用”。您可以安排它在非工作时间回收JVM进程。

您的JVM build 1.6.0_11-b03非常古老,但所有1.6个HotSpot JVM都应支持jmap

答案 1 :(得分:12)

没有

System.gc()向GC建议您想要收藏。

此外,在安静期间可能产生的垃圾很少,这就是为什么调用System.gc()并没有做太多的事情。

在高峰时段,可能会有更多活动,因此产生更多垃圾 - 因此需要收集。

很明显,你不能以这种简单的方式推迟收集。 JVM将在需要时收集。

你需要考虑调整你的GC - 如果你已经停止了世界收藏,那么你有一些问题。这不应该在现代服务器JVM上发生。

您应该考虑调整CMS收集器 - this是一篇关于Java系统基础知识的非常好的文章。在Java 7中,有新的G1GC可能会或可能不会更好。

您应该找到一种模拟负载条件并尝试不同GC参数的方法,CMS GC有许多调整参数,配置它有点暗示......

This是一篇关于GC调优和基准测试的文章。

答案 2 :(得分:3)

我会说是的 - 为您的安静时间安排一个过程,让您相信会触发GC。

吃一些严肃的记忆。分配一大堆物体并使用弱引用来跟踪它们 - 只需在您应该触发GC的安静时间做一些事情。

确保您有一些检测GC的逻辑并停止该过程。

答案 3 :(得分:1)

由于垃圾收集器不确定,因此无法强制立即收集。