Java虚拟机来一发(四)JVM调优和问题排查

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来调整二者之间的大小。

 

参考资料:

https://www.cnblogs.com/csniper/p/5592593.html

你可能感兴趣的:(Java虚拟机来一发)