HSDB(Hotspot Debugger) 使用

2019-08-27  本文已影响0人  addisJS

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. 使用说明

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. 线程说明

线程

6. main线程栈数据分析

线程数据
查看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] 
 ]  
]
上一篇 下一篇

猜你喜欢

热点阅读