项目中如何排查JVM问题?

123 阅读3分钟

在项目中排查JVM问题是一个系统性的过程,涉及多个步骤和工具的使用。

以下将详细介绍排查过程:

排查过程

  1. 收集问题相关信息

    • 记录问题发生的时间、频率和具体的错误信息或异常堆栈跟踪。
    • 获取应用程序的日志文件、JVM的日志文件、线程转储(Thread Dump)、内存转储(Heap Dump)等相关信息。
  2. 检查系统资源

    • 查看系统的CPU使用率、内存使用情况、磁盘IO等是否正常。可以使用topvmstatiostat等Linux命令来检查。
  3. 分析JVM日志

    • 查看GC日志,了解GC情况、内存分配情况和回收频率等。可以使用jstat命令或VisualVM等工具来分析。
  4. 线程转储(Thread Dump)分析

    • 获取应用程序的线程转储,了解线程的状态、堆栈信息和可能的死锁情况。可以使用jstack命令生成线程转储文件,并使用文本编辑器或专门的工具(如MAT、VisualVM)进行分析。
  5. 内存转储(Heap Dump)分析

    • 获取应用程序的内存转储,了解内存使用情况、对象占用内存较多的情况和可能的内存泄漏。可以使用jmap命令生成内存转储文件,并使用MAT、VisualVM等工具进行分析。
  6. 使用性能分析工具

    • 使用VisualVM、JProfiler等性能分析工具对应用程序进行性能分析,查看方法执行时间、方法调用关系、CPU消耗较高的代码等信息。

案例

案例:线上服务频繁Full GC,CPU占用率高

  1. 使用jstat查看GC情况

    jstat -gcutil <pid> 1000 10
    

    其中<pid>是Java进程的ID,该命令每1000毫秒输出一次GC情况,共输出10次。观察Full GC的次数和耗时,如果Full GC频繁且耗时较长,则可能是问题所在。

  2. 使用jmap查看堆内存使用情况

    jmap -heap <pid>
    

    该命令可以查看堆内存的分配情况,包括新生代、老年代的大小和使用率。

  3. 导出Heap Dump进行分析

    jmap -dump:format=b,file=heapdump.hprof <pid>
    

    使用MAT或VisualVM等工具打开heapdump.hprof文件,分析内存泄漏或异常对象。

  4. 使用jstack查看线程状态

    jstack <pid>
    

    查看线程堆栈信息,定位是否有线程死锁或长时间阻塞的情况。

小结

步骤操作工具/命令说明
1收集问题相关信息日志文件、Heap Dump、Thread Dump记录问题详情,获取关键数据
2检查系统资源top, vmstat, iostat监控CPU、内存、磁盘IO等系统资源
3分析JVM日志jstat, VisualVM了解GC情况、内存分配和回收情况
4线程转储分析jstack分析线程状态、堆栈信息和死锁情况
5内存转储分析jmap, MAT, VisualVM分析内存使用情况、对象占用和内存泄漏
6使用性能分析工具VisualVM, JProfiler查看方法执行时间、调用关系和CPU消耗

欢迎访问我的(夏壹分享)公众号 和 博客(sanzhishu)后缀top