OM内存溢出定位
- 增加异常时记日志参数
-
-XX:+HeapDumpOnOutOfMemoryError
- 该参数在JVM内存溢出时会记录堆转储文件java_pid%p.hprof。(%p为进程号)
-XX:HeapDumpPath=/tmp/dump
- 该参数设置堆转储文件保存的目录。
-
- GC分析
- 查看JVM的设置
- jps -v|grep pid
- jinfo pid
- 垃圾回收器的类型
- gc的原因
- jstat -gccause pid
- gc的次数和时间统计
- jstat -gcutil pid
- jvm内存使用情况
- 各代占用大小
- jstat -gccapacity
-
单位是KB
可以显示,VM内存中三代(young,old,perm)对象的使用和占用大小,如:PGCMN显示的是最小perm的内存使用量,PGCMX显示的是perm的内存最大使用量,PGC是当前新生成的perm内存占用量,PC是但前perm内存占用量。其他的可以根据这个类推, OC是old内纯的占用量。
-
- jstat -gccapacity
- 查看内存最多的对象,并查看GCROOT
- 导出堆转储文件后使用MAT工具进行分析
- jmap -dump:format=b,file=dump pid
- pid可通过jps获取
- 查看Dump文件
- 使用MAT工具分析
- jhat查看堆栈文件
- jhat dumpfile
- 通过7000端口查看
- jhat dumpfile
- jmap -dump:format=b,file=dump pid
- 导出堆转储文件后使用MAT工具进行分析
- 各代占用大小
- 查看JVM的设置