在生产环境中,有时候会遇到Java应用程序因发生OOM而导致服务挂掉的情况,可以通过dump文件来分析jvm信息。
1、获取JVM的dump文件的两种方式
1.1 JVM启动时增加两个参数
#出现 OOME 时生成堆 dump: -XX:+HeapDumpOnOutOfMemoryError #生成堆文件地址: -XX:HeapDumpPath=/opt/jvmlogs/
1.2 通过指令直接生成当前JVM的dump文件
jmap -dump:format=b,file=/tmp/heap.jmap JAVA_PID
说明:在pod里执行,需要先进入到pod查看Java进程的PID,然后执行该指令,然后把dump文件复制到本地
kubectl exec -it ps -ef jmap kubectl cp
第一种方式是事后方式,需要等待当前JVM出现问题后才能生成dump文件,实时性不高,
第二种方式在执行时,JVM是暂停服务的,所以对线上的运行会产生影响,所以建议第一种方式。
2. 查看JVM信息
2.1 查看整个JVM内存状态
jmap -heap [pid]
2.2 查看JVM堆中对象详细占用情况
jmap -histo [pid]
参考博客 https://www.cnblogs.com/ainimore/p/13345831.html