我有一个24x6计划运行的应用程序。目前,在运行几天后,会自动执行Full GC - 通常在一天的繁忙时段执行,这会对用户响应时间产生负面影响。
我想做的是强制使用全GC - 可能在每晚的午夜,在非常低的使用时间内 - 以防止它在白天发生。我已经尝试过System.gc(),但它似乎并不能保证何时会发生Full GC,或者即使它会发生。有没有办法做到这一点?
版本信息:
Java(TM)SE运行时环境(版本1.6.0_11-b03)
Java HotSpot(TM)服务器VM(版本11.0-b16,混合模式)
另外 -
更具体地说,我正在寻找一种技术来确保完整GC的发生,而不是一个简单的方法/函数来调用它。
目前,我正在考虑修改CMS使用的百分比阈值,以确定何时需要完整GC。
感谢您的帮助。
答案 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)
由于垃圾收集器不确定,因此无法强制立即收集。