zoukankan      html  css  js  c++  java
  • Java内存分析(1) 基本概念说明

    1.Heap Dump

    如果你不知道Java里面的Heap是什么意思,这篇文章可能就不太适合你阅读了。

    一个Heap Dump是指在某个时刻对一个Java进程所使用的内存情况的一次快照。也就是在某个时刻把Java进程的内存以某种格式持久化到了磁盘上。Heap Dump的格式有很多种,而且不同的格式包含的信息也可能不一样。但总的来说,Heap Dump一般都包含了一个堆中的Java Objects, Class等基本信息。同时,当你在执行一个转储操作时,往往会触发一次GC,所以你转储得到的文件里包含的信息通常是有效的内容(包含比较少,或没有垃圾对象了)

    我们往往可以在Heap Dump以下基本信息(一项或者多项,与Dump文件的格式有关):

    • 所有的对象信息
      对象的类信息、字段信息、原生值(int, long等)及引用值
    • 所有的类信息
      类加载器、类名、超类及静态字段
    • 垃圾回收的根对象
      根对象是指那些可以直接被虚拟机触及的对象
    • 线程栈及局部变量
      包含了转储时刻的线程调用栈信息和栈帧中的局部变量信息

    一个Heap Dump是不包含内存分配信息的,也就是说你无法从中得知是谁创建了这些对象,以及这些对象被创建的地方是哪里。

    但是通过分析对象之间的引用关系,往往也能推断出相关的信息了。

    2.如何获取Heap Dump文件

    下面介绍一下常用的三种获取Heap Dump的方式

    当OutOfMemoryError发生时

    这可是一个相当便捷的参数了,因为当你需要分析Java内存使用情况时,往往是在OOM(OutOfMemoryError)发生时。那么通过在你的启动脚本中,为Java命令添加以下参数,就可以得到一份内存信息了:

    Java –Xmx1024m …. -XX:+HeapDumpOnOutOfMemoryError ……

    交互式地获取Heap Dump

    说实话,我还没用过这个方式,但看起来很方便。和上面的方式类似,也是添加一个Java命令选项,然后你就可以通过使用快捷键Ctrl + Break去获取当前的内存转储信息了。

    Java –Xmx1024m …. -XX:+HeapDumpOnCtrlBreak ……

    使用工具获取

    这是我常用的方式,通过JDK自带的一些小工具,你可以参考一下http://blog.romebuilder.com/2011/06/393/

    这里主要用到了jps, jmap

    通过jps得到Java进程的PID,然后使用jmap转储

    jmap –dump:format=b,file=heap.bin PID

    还有基本的GUI工具也可以达到类似的效果,如jconsol, Eclipse memory analyzer等,大家可以自己去摸索一下,不过以上提到方法也已经能够满足大多数的应用场景了吧。

    后续文章会说明如何分析得到的Heap Dump文件..... 

  • 相关阅读:
    常见搜索召回方式
    阿里Tree-based Deep Match(TDM) 学习笔记
    阻塞、非阻塞、同步、异步的理解
    最佳实践:深度学习用于自然语言处理(Deep Learning for NLP Best Practices)
    ELK日志分析工具
    mysql性能测试--sysbench实践
    mysql性能测试-tpcc
    mysql基础测试
    压力测试sysbench
    压力测试工具MySQL mysqlslap
  • 原文地址:https://www.cnblogs.com/ungshow/p/2432846.html
Copyright © 2011-2022 走看看