一.-x 和 -xx 参数
https://www.oracle.com/technetwork/java/javase/tech/vmoptions-jsp-140102.html
X参数是非标准的参数
-Xint:解释执行 | -Xcomp:第一次使用就编译成本地代码 | -Xmixed:混合模式,jvm自己来决定是否编译成本地代码。
平时我们java -version看到的mixed mode就是这个意思:
XX参数是一种非标准化的参数,相对不是很稳定,用户可以自己设置,jvm调优和debug都是用这些参数。主要分为以下两大类:
1、Boolean类型
格式:-XX:[+-]<NAME>表示启用或者禁用name属性 | 比如:-XX:+UseConcMarkSweepGC | -XX:+UseG1GC
2、非Boolean类型
格式:-XX:<NAME>=<VALUE>表示name属性的值是value | 比如:XX:MaxGCPauseMillis=500 | XX:GCTimeRatio=19
3、特例
不是X参数,而是XX参数 | -Xms等价于-XX:InitialHeapSize | -Xmx等价于-XX:MaxHeapSize
二.JVM之对象分配:栈上分配 & TLAB分配 https://blog.youkuaiyun.com/qq_30509055/article/details/93912227
-Xms20M starting 堆的起始大小
-Xmx max 堆的最大值
-Xmn new 堆的新生代(影响新生代大小的参数 -XX:NewRatio=n)对象分配eden :-XX:SurvivorRatio=8 8:1:1
进入老年代配置
对象很大
-XX:PretenureSizeThreshold=3145728 3M
长期存活的对象
-XX:MaxTenuringThreshold=15 【】
动态对象年龄判定
相同年龄所有对象的大小总和 > Survivor空间的一半
分配担保
Minor GC 之前检查 老年代最大可用连续空间是否>新生代所有对象总空间是否大于历代晋升老年代平均大小
Minor GC:新生代回收算法
Major GC:老年代回收算法
Full GC:Minor GC + Major GC【各种垃圾回收器最终目的是减少Full GC】
三.垃圾对象回收
JVM中的垃圾回收算法
1. 标记-清除(Mark-Sweep) 标记清除流程
jvm会扫描所有的对象实例,通过根搜索算法,将活跃对象进行标记,jvm再一次扫描所有对象,将未标记的对象进行清除,只有清除动作,不作任何的处理,这样导致的结果会存在很多的内存碎片。
2. 复制(copying)复制流程
jvm扫描所有对象,通过根搜索算法标记被引用的对象,之后会申请新的内存空间,将标记的对象复制到新的内存空间里,存活的对象复制完,会清空原来的内存空间,将新的内存最为jvm的对象存储空间。这样虽然解决了内存内存碎片问题,但是如果对象很多,重新申请新的内存空间会很大,在内存不足的场景下,会对jvm运行造成很大的影响
3. 标记-整理(Mark-compact) 标记整理流程
标记整理实际上是在标记清除算法上的优化,执行完标记清除全过程之后,再一次对内存进行整理,将所有存活对象统一向一端移动,这样解决了内存碎片问题。
4. 分代回收 分代回收算法
目前jvm常用回收算法就是分代回收,年轻代以复制算法为主,老年代以标记整理算法为主。原因是年轻代对象比较多,每次垃圾回收都有很多的垃圾对象回收,而且要尽可能快的减少生命周期短的对象,存活的对象较少,这时候复制算法比较适合,只要将有标记的对象复制到另一个内存区域,其余全部清除,并且复制的数量较少,效率较高;而老年代是年轻代筛选出来的对象,被标记比较高,需要删除的对象比较少,显然采用标记整理效率较高。
七种垃圾收集器https://blog.youkuaiyun.com/qq_30509055/article/details/94210131
Serial【单线程】
ParNew 【多个线程 默认】
-XX:ParallelGCThreads
Parallel Scavenge (全局)
吞吐量 = 运行用户代码时间 / (运行用户代码时间 + 垃圾收集时间)
-XX:MaxGCPauseMillis=n 【gc停顿时间 不建议设置 也不一定管用】
-XX:GCTimeRatio=n
-XX:UseAdaptiveSizePolicy GC Ergonomics【】
Serial Old
CMS备用预案 Concurrent Mode Failusre时使用
标记-整理算法
Parallel Old
标记-整理算法
CMS
标记-清除算法
减少回收停顿时间
碎片 -XX:CMSInitiatingOccupancyFraction
Concurrent Mode Failure 启用Serial Old
-XX:+UseCMSCompactAtFullCollection
-XX:CMSFullGCsBeforeCompaction 执行多少次不压缩FullGC后 来一次带压缩的 0 表示每次都压
-XX:+UseConcMarkSweep并行与并发
G1
并行与并发;分代收集;空间整理 (标记整理算法,复制算法);可预测的停顿
应用线程和GC线程同步,GC运行时不是在任何时间节点让所有应用线程停止。有两种中断方式
抢占式:GC线程运行时应用线程会检查自己是否在安全点(执行比较久的构成之前或之后,例如:方法调用,异常跳转),如 果在就停止,不在就继续运行至到安全点
主动式:GC线程运行时会设置flag ,当应用线程运行时会检查GC是否在运行,如果在运行则主动停止。