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 去哪里了?
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,607评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,047评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,496评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,405评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,400评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,479评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,883评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,535评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,743评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,544评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,612评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,309评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,881评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,891评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,136评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,783评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,316评论 2 342

推荐阅读更多精彩内容

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