jvm生成dump文件并导出
jvm生成dump文件并导出
在生产环境中,有时候会遇到Java应用程序因发生OOM而导致服务挂掉的情况,可以通过dump文件来分析jvm信息。
1、获取JVM的dump文件的两种方式
1.1 JVM启动时增加两个参数
#出现 OOME 时生成堆 dump: -XX:+HeapDumpOnOutOfMemoryError #生成堆文件地址: -XX:HeapDumpPath=/opt/jvmlogs/
[appdeploy@fw-open-backend-newenv-59c8687cf7-jjx44 deploy]$ps -ef|grep java
appdepl+ 91 89 0 Jun01 ? 00:05:37 java -javaagent:/home/appdeploy/apm-agent/skywalking-agent.jar=statuscheck.ignored_exceptions=com.sf.fns.edi.common.exception.EdiBizException -server -Xmx2G -Xms2G -XX:+UseG1GC -XX:MaxGCPauseMillis=20 -XX:InitiatingHeapOccupancyPercent=35 -XX:+ExplicitGCInvokesConcurrent -XX:MaxInlineLevel=15 -Djava.awt.headless=true -Djava.awt.headless=true -Djava.net.preferIPv4Stack=true -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=1099 -Dcom.sun.management.jmxremote.rmi.port=1099 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -jar /app/deploy/lib/fw-open-backend-1.0.0.jar --spring.config.location=conf/
appdepl+ 2203 2165 0 18:47 pts/0 00:00:00 grep --color=auto java
[appdeploy@fw-open-backend-newenv-59c8687cf7-jjx44 deploy]$
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]
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix