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 去哪里了?