背景:在一些情况下,机器内存使用率一直居高不下,那么可以查询下是进程占用内存情况,JVM中使用jmap查看(导出)进程堆栈内存使用情况。至今,反正我咩有找到可以在线诊断的工具,不像CPU可以在线定位到问题所在的行。如果有,请告诉我好吗。
1、查看内存占用高的进程PID
$top #或者jps
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
15288 sc 20 0 5772808 1.797g 6320 S 25.9 46.6 64:02.91 java
2、切换到root用户
$su root
3、查看进程15288 heap使用情况
#/opt/sc/java8/bin/jmap -heap 15288
接下来要注意,如果要判断是否有内存泄漏,那下面的命令参数中不能带live,原因是live参数会触发一次FULLGC。
4、分析具体的对象占用
$ jmap -histo:live 15288
导出PID为15288的heap信息到文件/home/sc/outfile
5、 导出整个JVM 中内存信息
jmap -dump:format=b,file=文件名 [pid] #不能带live参数,原因还是live参数会触发一次FULLGC。
#/opt/sc/java8/bin/jmap -dump:format=b,file=/home/sc/outfile 15288
接下来就可以用eclipse MAT工具进行分析了。
这些需要注意,如果要排除内存泄漏问题,请不要加上live参数,因为live会触发一次FULLGC。