JVM调优 - JiyangM/spring GitHub Wiki

JVM内存分配回收

参考《Java虚拟机第二版》

运行日志、异常堆栈、GC日志、线程快照

参数调优

-Xmx4g:堆内存最大值为4GB。

-Xms4g:初始化堆内存大小为4GB 。

-Xmn1200m:设置年轻代大小为1200MB。增大年轻代后,将会减小年老代大小。此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8。

-Xss512k:设置每个线程的堆栈大小。JDK5.0以后每个线程堆栈大小为1MB,以前每个线程堆栈大小为256K。应根据应用线程所需内存大小进行调整。在相同物理内存下,减小这个值能生成更多的线程。但是操作系统对一个进程内的线程数还是有限制的,不能无限生成,经验值在3000~5000左右。

-XX:NewRatio=4:设置年轻代(包括Eden和两个Survivor区)与年老代的比值(除去持久代)。设置为4,则年轻代与年老代所占比值为1:4,年轻代占整个堆栈的1/5

-XX:SurvivorRatio=8:设置年轻代中Eden区与Survivor区的大小比值。设置为8,则两个Survivor区与一个Eden区的比值为2:8,一个Survivor区占整个年轻代的1/10

-XX:PermSize=100m:初始化永久代大小为100MB。

-XX:MaxPermSize=256m:设置持久代大小为256MB。

-XX:MaxTenuringThreshold=15:设置垃圾最大年龄。如果设置为0的话,则年轻代对象不经过Survivor区,直接进入年老代。对于年老代比较多的应用,可以提高效率。如果将此值设置为一个较大值,则年轻代对象会在Survivor区进行多次复制,这样可以增加对象再年轻代的存活时间,增加在年轻代即被回收的概论。

命令行

  • jps :查看正在运行的虚拟机进程。

  • jstat:是用于监视虚拟机各种运行状态信息,查看新生代、老生代及持代垃圾收集的情况

  • jinfo : 获取一些当前进程的jvm运行和启动信息。

  • jmap :命令用于生产堆转存快照。打印出某个java进程(使用pid)内存内的,所有‘对象’的情况(如:产生那些对象,及其数量)。

  • jstack : jstack用于生成java虚拟机当前时刻的线程快照。线程快照是当前java虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的主要目的是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间等待等。


应用

CPU飙升

  • 1.找到最耗CPU的进程 : top
  • 2.找到该进程下最耗费cpu的线程: top -Hp pid
  • 3.过滤指定线程,打印堆栈信息 : jstack pid |grep

线程死锁

  • 1.查找java进程id : top 或者 jps
  • 2.查看java进程的线程快照信息: jstack -l pid

OOM内存泄露

  • 1.查看新生代,老生代堆内存的分配大小以及使用情况,看是否本身分配过小:jmap -heap 11869

  • 2.排查gc: 特别是fgc情况下,各个分代内存情况。

https://juejin.im/post/59f02f406fb9a0451869f01c

https://juejin.im/post/59e6c1f26fb9a0451c397a8c

https://blog.csdn.net/gyqjn/article/details/49848473