JVM 问题排查

- Java JVM

可正常运行系统:

  1. 通过jmap来查看JVM中各个区域的使用情况
  2. 通过jstack来查看线程的运行情况,比如哪些线程阻塞、是否出现死锁
  3. 通过jstat来查看垃圾回收情况,特别是fullgc,如果发现fullgc比较频繁,那么就得进行调优
  4. 通过各个命令的结果或者jvisualvm等工具来进行分析
  5. 首先:初步猜测频发发送fullgc的原因,如果频繁发生fullgc,但是又一直没有出现内存溢出,那么表示fullgc实际上回收了很多对象,所以这些对象最好能在younggc过程中直接回收掉,避免这些对象进入到老年代,对于这种情况,就要考虑这些存活时间不长的对象是不是比较大,导致年轻代放不下,直接进入到老年代,尝试加大年轻代的大小,如果改完之后,fullgc减少,则证明修改有效
  6. 同时,还可以找到占用CPU最多的线程,定位到具体的方法,优化这个方法的执行,看是否能避免某些对象的创建,从而节省内存

运行中发生OOM的系统:

  1. 一般生产系统中都会设置当前系统发生了OOM时,生成当时的dump文件(-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/usr/local/base
  2. 我们可以利用jvisualvm等工具来分析dump文件
  3. 根据dump文件找到异常的实例对象和异常的线程(占用CPU高),定位到具体代码
  4. 然后再进行详细的分析和调试