JVM内存、堆模型、垃圾回收器总结
2017-11-06 10:10
375 查看
全栈进行时 2017-10-24 15:18
需要注意的是,JDK8中已经用Metaspace(元数据区)完全替代了永久代(即方法区),而且元数据区内存不在JVM中,而是使用的本地内存,默认情况下受操作系统内存限制。
调整元数据区内存大小的参数: -XX:MetaspaceSize -XX:MaxMetaspaceSize
-Xms和-Xmx
用于设置堆内存的大小
-XX:NewSize和-XX:MaxNewSize
用于设置年轻代的大小,建议设为整个堆大小的1/3或者1/4,两个值设为一样大。
-XX:SurvivorRatio
用于设置Eden和其中一个Survivor的比值,这个值也比较重要。
-XX:NewRatio=3代表新生代和老年代的比例为1:3
GC主要分二类,新生代GC,老年代GC;
新生代GC包括:串行GC、并行GC、并行回收GC
老年代GC包括:串行GC、并行GC、CMS
G1比较特殊,同时支持新生代和老年代
对于吞吐量优先的采用server默认的并行GC(Parallel GC)方式(上图蓝色区域),
对于暂停时间优先的选用并发GC(CMS)方式(上图黄色区域),常用场景:互联网、电商类
开启方式[ -XX:+UseConcMarkSweepGC -XX:+UseParNewGC ]
吞吐量优先: 并行回收GC + 并行GC
开启方式 [ -XX:+UseParallelOldGC ] ,此GC也时server模式默认的配置
G1: [ -XX:+UseG1GC ]
适用于服务器端、大内存、多CPU情景的垃圾收集器;
G1的目标是在维持高效率回收的同时,提供软实时中断特性
常用场景:hadoop、elasticsearch
G1 堆 -> 多个区 -> 每个区里(年轻代老年代)
Cms 标记清理算法
G1 压缩复制算法,不产生碎片
G1 时间停顿可设置,相关参数[ -XX:MaxGCPauseMillis=100 -XX:GCPauseIntervalMillis=200 ]
JVM8内存
包括:堆、栈、元数据区、本地方法栈、程序记数寄存器
需要注意的是,JDK8中已经用Metaspace(元数据区)完全替代了永久代(即方法区),而且元数据区内存不在JVM中,而是使用的本地内存,默认情况下受操作系统内存限制。
调整元数据区内存大小的参数: -XX:MetaspaceSize -XX:MaxMetaspaceSize
JVM堆内存
-Xms和-Xmx
用于设置堆内存的大小
-XX:NewSize和-XX:MaxNewSize
用于设置年轻代的大小,建议设为整个堆大小的1/3或者1/4,两个值设为一样大。
-XX:SurvivorRatio
用于设置Eden和其中一个Survivor的比值,这个值也比较重要。
-XX:NewRatio=3代表新生代和老年代的比例为1:3
垃圾回收器
GC主要分二类,新生代GC,老年代GC;
新生代GC包括:串行GC、并行GC、并行回收GC
老年代GC包括:串行GC、并行GC、CMS
G1比较特殊,同时支持新生代和老年代
GC选择:
GC在选择上,主要关注两点,吞吐量优先和暂停时间优先,对于吞吐量优先的采用server默认的并行GC(Parallel GC)方式(上图蓝色区域),
对于暂停时间优先的选用并发GC(CMS)方式(上图黄色区域),常用场景:互联网、电商类
常用GC开启方式
暂停时间优先: 并行GC + CMS开启方式[ -XX:+UseConcMarkSweepGC -XX:+UseParNewGC ]
吞吐量优先: 并行回收GC + 并行GC
开启方式 [ -XX:+UseParallelOldGC ] ,此GC也时server模式默认的配置
G1: [ -XX:+UseG1GC ]
适用于服务器端、大内存、多CPU情景的垃圾收集器;
G1的目标是在维持高效率回收的同时,提供软实时中断特性
常用场景:hadoop、elasticsearch
CMS和G1区别
Cms 堆 -> 年轻代老年代G1 堆 -> 多个区 -> 每个区里(年轻代老年代)
Cms 标记清理算法
G1 压缩复制算法,不产生碎片
G1 时间停顿可设置,相关参数[ -XX:MaxGCPauseMillis=100 -XX:GCPauseIntervalMillis=200 ]
相关文章推荐
- JVM 内存模型和垃圾回收(三): 并行回收器
- JVM 内存模型和垃圾回收(二): 串行垃圾回收器
- JVM-内存模型及垃圾收集算法
- JVM内存模型以及垃圾收集策略解析
- JVM内存模型及垃圾收集策略解析(3)
- JVM的stack和heap,JVM内存模型,垃圾回收策略,分代收集,增量收集
- JVM内存模型及垃圾回收机制
- JVM内存模型及垃圾收集策略解析
- JVM内存模型以及垃圾收集策略解析
- JVM内存模型以及垃圾回收
- JVM内存模型以及垃圾回收
- JVM内存模型以及垃圾收集策略解析【续】
- JVM内存模型及垃圾收集策略解析(一)
- 转:JVM内存模型以及垃圾收集策略解析
- Java(JVM)内存模型和垃圾回收监控与调整
- jvm的stack和heap,JVM内存模型,垃圾回收策略,分代收集,增量收集
- JVM内存模型及垃圾收集策略解析(1)
- JVM内存模型及垃圾收集策略解析
- 二,JVM的内存模型,(GC)垃圾处理,调优监控(基于HotSpot VM,JDK1.5+)【JAVA内存模型】
- JVM内存模型及垃圾回收机制