1、JVM问题排查
1)top命令查看高内存占用情况;
2)非mapp用户,没办法使用jstack、jmap等命令,先sudo su mapp切换到mapp用户;
3)jmap -heap pid 查看堆内存和GC;
4)jstack -F pid 查看BLOCK的线程,可以查看死锁;
5)查看用时高的线程 ps -mp tid -o THREAD,tid,time|sort -rn|head -n 20
内存泄漏的情况下GC次数会越来越多,老年代内存会越来越大,逐渐达到OutOfMemoryError临界值。
2、JVM优化原则
JVM调优目标是GC时间足够小,GC次数足够少,发生FullGC周期足够长。
1)针对JVM堆的设置,一般可以通过-Xms -Xmx限定其最小、最大值,为了防止垃圾收集器在最小、最大之间收缩堆而产生额外的时间,我们通常把最大、最小设置为相同的值。
2)更大的年轻代必然导致更小的年老代,大的年轻代会延长普通GC的周期,但会增加每次GC的时间;小的年老代会导致更频繁的Full GC。可以通过调整二者之间的比率NewRadio来调整二者之间的大小。
参考资料: