HSDB(Hotspot Debugger) 使用

1. JAVA_HOME确认,方便起见, 添加sa-jdi.jar到classpath中

JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk-11.0.1.jdk/Contents/Home
CLASSPAHT=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/sa-jdi.jar
PATH=$JAVA_HOME/bin:$PATH:
export JAVA_HOME
export CLASSPATH
export PATH

source .bash_profile

2. 命令行启动HSDB

sudo java -cp $CLASSPATH  sun.jvm.hotspot.HSDB

3. 使用说明

  • HSDB
  • 借HSDB来探索HotSpot VM的运行时数据
  • 怎么查看运行时常量池的数据?
  • 代码样例

4. 程序测试

public static void main(String[] args) {
        LockBean lockBean = new LockBean();
//        new Thread(() -> {
//            synchronized (lockBean) {
//                try {
//                    Thread.sleep(1000l);
//                } catch (InterruptedException e) {
//                    e.printStackTrace();
//                }
//            }
//        }).start();

        synchronized (lockBean) {
            try {
                Thread.sleep(1000l);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }

5. 线程说明

线程
  • Signal Dispatcher 进程通信,attach机制核心线程(还有一个attach listener 执行JVM命令时会启动)
  • Finalizer 遍历执行F-Queue(java.lang.ref.Finalizer.ReferenceQueue Reference/ReferenceQueue 详解)队列中对象的finalize方法,只有当F-Queue中对象finalize执行完成后,并且下次GC时可达性分析不在GC Roots的引用链上,则这些对象占用的内存才能被真正回收
  • Reference Handler 它主要用于处理引用对象本身(软引用、弱引用、虚引用)的垃圾回收问题
  • main 程序入口

6. main线程栈数据分析

HSDB(Hotspot Debugger) 使用_第1张图片
线程数据
查看lockBean变量
hsdb> inspect 0x00000007957fcfd0
instance of Oop for com/addis/runner/LockBean @ 0x00000007957fcfd0 @ 0x00000007957fcfd0 (size = 16)
_mark: 1
_metadata._compressed_klass: InstanceKlass for com/addis/runner/LockBean
注--> LockBean 没有实例字段 占位16byte
lockBean具体数据
hsdb> mem 0x00000007957fcfd0 2
0x00000007957fcfd0: 0x0000000000000001 注-->mark word
0x00000007957fcfd8: 0x00000000f800c405 注-->8byte 补0 +8byte klass_pointer

7. Heap/GC代 分析

hsdb> universe
ParallelScavengeHeap 
[ 
 PSYoungGen [ 
  eden =  [0x0000000795580000,0x00000007958c0170,0x0000000797600000] , 
  from =  [0x0000000797b00000,0x0000000797b00000,0x0000000798000000] , 
  to =  [0x0000000797600000,0x0000000797600000,0x0000000797b00000]  
 ] 
 PSOldGen [  
  [0x0000000740000000,0x0000000740000000,0x0000000745580000] 
 ]  
]
  • JDK8 取消了PermGen, metadata 存储在MetaSpace中(本地内存Native memory), 每一个class loader会申请自己的一个meta space, 该meta space的生命周期随着class loader被gc而结束. meta space拥有的chunks会被回收到可用块列表(用于后续分配) , chunk划分成blocks,每个block存储一个meta data.
    参考 Java PermGen 去哪里了?

你可能感兴趣的:(HSDB(Hotspot Debugger) 使用)