今天收到测试小姐姐提的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资源较高,接下来去查看这个进程是什么。