java.lang.OutOfMemoryError内存溢出定位

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内纯的占用量。

      • 查看内存最多的对象,并查看GCROOT
        • 导出堆转储文件后使用MAT工具进行分析
          • jmap -dump:format=b,file=dump pid
            • pid可通过jps获取
          • 查看Dump文件
            • 使用MAT工具分析
            • jhat查看堆栈文件
              • jhat dumpfile
                • 通过7000端口查看  
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值