JAVA获取线上堆栈信息

9 篇文章 0 订阅
6 篇文章 0 订阅

问题描述

服务部署到线上以后隔一段时间就无法访问了,后台日志提示:java.lang.OutOfMemoryError: GC overhead limit exceeded,初步判断为内存泄露;下一步就是获取堆栈信息进行分析;

1.使用jmap生成dump文件

jmap -dump:format=b,file=[FILE_NAME].dump [PID]

  1. FILE_NAME: 文件名
  2. PID 线程ID

2.使用kill -3 PID 获取堆栈信息

  1. 获取进程的PID ps -ef|grep java
  2. 获取堆栈信息 kill -3 PID
  3. 获取文件

1> 如果项目通过Tomcat进行发布(普通的web项目),则对应的堆栈信息会打印在catalina.out文件中。
2> 如果项目是基于SpringBoot并且使用nohup java -jar xxx.jar & 命令运行,则java堆栈信息会在jar包所在的nohup.out文件中。

3.分析日志

将dump文件导入VisualVm中分析,文件 => 装入 即可分析

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值