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

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线程栈数据分析

线程数据
查看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 去哪里了?
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 官网 中文版本 好的网站 Content-type: text/htmlBASH Section: User ...
    不排版阅读 9,954评论 0 5
  • 1.创建文件夹 !/bin/sh mkdir -m 777 "%%1" 2.创建文件 !/bin/sh touch...
    BigJeffWang阅读 13,464评论 3 53
  • 说明:不少读者反馈,想使用开源组件搭建Hadoop平台,然后再部署Kylin,但是遇到各种问题。这里我为读者部署一...
    大诗兄_zl阅读 6,316评论 0 2
  • 一、JDK的安装 1、Java-Package choose 上述文档翻译: JDK:针对Java开发者(Java...
    7叶阅读 5,227评论 1 2
  • 阴雨。 很累了。网络太厉害。 早上英美社会老师很温柔,还好。视听也挺好,很放松。看来以后的周五是比较轻松的了。 中...
    Cheryl_ak717阅读 1,482评论 0 0