jvm
java虚拟机组成
- 类装载系统
- 执行引擎
- 运行时数据区
内存模型
1、堆
- new出来的对象存放在堆里面
- 年轻代(1/3占比),Eden(伊甸园去)8/10占比,servivor0 1/10占比,servivor1 1/10占比
- 老年代(2/3占比):静态变量引用的对象、spring容器的bin对象、controller、service、线程池、对象池、缓存对象…
- gc roots:线程栈、方法区两部分存放的本地变量、静态变量、本地方法栈的变量。gc时将gc roots 对象作为起点,从这些节点开始向下搜索引用对象,找到的对象标记为非垃圾对象,其余未标记的对象是垃圾对象。
- 可达性分析算法:
- 分代年龄:对象每经历一次gc,没有清除掉分代年龄会加1,年轻代中分代年龄达到15后会将对象移动到老年代中。
- minor gc:Eden(伊甸园去)8/10占比内存放满后会触发minor gc,回收年轻代的垃圾对象。gc期间会发生STW stop the world,但是持续时间会很短,几乎无影响。
- full gc:回收年轻代和老年代整个堆的内存空间进行垃圾回收。gc期间会发生STW stop the world。暂停用户线程,待回收后才可用。
- jvisualvm:jvm调优的可视化工具,需要配置插件
2、方法区
3、栈(线程)
- 程序运行main方法后会在栈中开辟一块独立的栈空间(专属的内存区域),区分不同方法的局部变量,即栈帧内存区域。
- 与数据结构中的栈类似,程序中方法先调用后结束。
- 占中包含 局部变量、操作数栈、动态链接、方法出口。
4、本地方法栈
5、程序计数器
类装载系统
字节码执行引擎
- 负责垃圾回收
jvm调优
- 减少full gc
- 分析每个对象的大小,每个对象的字节的总数*峰值的对象数量
垃圾回收算法
1、标记清除法
会产生磁盘碎片,磁盘空间不连续
2、标记复制
没有碎片,浪费空间
3、标记整理算法
没有碎片,效率偏低
垃圾收集器
1.1 新生代垃圾收集器
1.1.1 Serial 收集器
- Serial 是一款用于新生代的单线程收集器,采用复制算法进行垃圾收集
- 适用场景:Client 模式(桌面应用);单核服务器。
- 可以用 -XX:+UserSerialGC 来选择 Serial 作为新生代收集器。
1.1.2 ParNew 收集器
- ParNew 就是一个 Serial 的多线程版本
- 通过 -XX:ParallelGCThreads 来设置垃圾收集的线程数
- 默认开启的收集线程数和 CPU 数量一致
- 适用场景:多核服务器
1.1.3 Parallel Scavenge 收集器
- 一款用于新生代的多线程收集器
- Parallel Scavenge 的目标是达到一个可控制的吞吐量
- 吞吐量 = 运行用户代代码时间/(运行用户代码时间+垃圾收集时间)
- 适用场景:注重吞吐量,高效利用 CPU,需要高效运算且不需要太多交互
1.2 老年代垃圾收集器
1.2.1 Serial Old 收集器
- Serial Old 收集器是 Serial 的老年代版本,同样是一个单线程收集器,采用标记-整理算法。
- 适用场景:Client 模式(桌面应用),单核服务器
- 与 Parallel Scavenge 收集器搭配,作为 CMS 收集器的后备预案
1.2.2 CMS(Concurrent Mark Sweep) 收集器
- 以最短回收停顿时间为目标的收集器
1.2.3 Parallel Old 收集器
- Parallel Scavenge 的老年代版本,是一个多线程收集器,采用标记-整理算法
GC发展阶段
- Serial => Parallel (并行) => CMS(并发) => G1 => ZGC