如何排查JVM内存问题并定位

本文介绍了如何排查JVM内存问题及CPU飙高情况。首先通过jvisualvm观察内存使用,发现有规律GC导致CPU飙升。接着在服务器上查看进程和线程,使用top、ps、jstack等命令定位到CPU占用高的线程,发现是LOG4J日志打印过于频繁导致。最后调整日志级别为error,成功解决问题。
摘要由CSDN通过智能技术生成

今天收到测试小姐姐提的bug,在进行压测的时,内存和CPU都飙高,要我分析一下。

一、首先观察服务器上的内存使用情况

使用jdk自带的 jvisualvm.exe 功能(在jdk的bin目录下)

打开后连接远程服务器,具体如何连接请自行百度,连接后壳查看服务器的CPU和内存等情况。

● 如果是内存泄漏,堆内存会一直往上飙,然后会出现疯狂GC的情况。

● 我这里没有出现疯狂GC的情况,而是有规律的GC,但每次GC的时候CPU都会飙到70%以上。

ps:截图是问题处理完之后的截图,当时cpu使用情况已经飙到70% ~ 100%,堆内存占用1.3G的时候就会GC一次。

 二、到服务器上查看具体进程和线程:

登陆服务器,查看具体是哪个进程中的哪些线程造成CPU飙高。

1. 使用top命令查看占用CPU资源高的进程

这里可以看到PID为27737的进程占用CPU资源较高,接下来去查看这个进程是什么。

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值