在本文中会介绍一些常用的JVM调优思路以及调优方法,这些方法是为了解决某个具体问题,提高某个局部性能而特别设置的。 使用它们可能会对其他性能指标产生不良的影响,应该在实际应用中,根据具体情况进行折中和权衡。总结自《Java程序性能优化》
1.将新对象预留在新生代
由于Full GC的成本远高于Minor GC,因此尽可能将对象分配在新生代是一项明智的做法。虽然在大部分情况下,JVM会尝试在eden区分配对象,但是由于空间紧张等问题,很可能不得不将部分年轻对象提前向老年代压缩。
在JVM参数调优中,可以为应用程序分配一个合理的新生代空间,以避免新对象直接进入老年代的情况。因为新生代垃圾回收的速度高于老年代回收。因此,将年轻对象预留在新生代有利于提升整体的GC效率。
2.大对象进入老年代
虽然在大部分情况下,将对象分配在新生代是合理的。但是,对于大对象,这种做法是值得商榷的。大对象出现在新生代很可能扰乱新生代GC,并破坏新生代原有的对象结构。
因为尝试在新生代分配大对象,很可能导致空间不足,为了有足够的空间容纳大对象,JVM不得不将新生代中的年轻对象挪到老年代。因为大对象占用空间多,所以可能需要移动大量的小的年轻对象进入老年代。因为新生代的对象往往存活时间比较短,所以会引起多次的Full GC造成程序卡顿。
基于以上的原因,可以直接将大对象分配到老年代,以保持新生代对象结构的完整性,提高GC的效率。
可以使用参数-XX:PretenureSizeThreshold设置大对象直接进入老年代的阈值。当对象的大小超过这个值,将直接在老年代分配。