jvm生成dump文件并导出

在生产环境中,有时候会遇到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

posted on   流年似水zlw  阅读(4128)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

点击右上角即可分享
微信分享提示