GC和GC Tuning

JVM 调优GC和GC Tuning

GC的基础知识

1.什么是垃圾

C语言申请内存:malloc free

C++: new delete

Java: new ?

自动内存回收,编程上简单,系统不容易出错,手动释放内存,容易出两种类型的问题:

  1. 忘记回收
  2. 多次回收

没有任何引用指向的一个对象或者多个对象(循环引用)

2.如何定位垃圾
  1. 引用计数
  2. 根可达算法
    跟对象只想指向的对象及指向的对象都不是垃圾。
  3. which instance are roots? 哪写对象是根对象
    线程栈对象
    静态变量
    常量池
    JNI指针
3.常见的垃圾回收算法
  1. 标记清除 - 位置不连续 产生碎片 mark-sweep 在这里插入图片描述

  2. 拷贝算法 - 没有碎片,浪费空间 copying在这里插入图片描述

  3. 标记压缩 - 没有碎片,效率偏低 mark-Compact
    在这里插入图片描述

4.JVM内存分代模型(用于分代垃圾回收算法)
  1. 部分垃圾回收器使用的模型
  2. 新生代 + 老年代 + 永久代(1.7)/ 元数据区(1.8) Metaspace
    1. 永久代 元数据 - 存储Class对象
    2. 永久代必须指定大小限制 ,元数据可以设置,也可以不设置,无上限(受限于物理内存)
    3. 字符串常量 1.7 - 永久代,1.8 - 堆
    4. MethodArea是逻辑概念 - 永久代、元数据
      堆内存逻辑分区
      在这里插入图片描述
      伊甸区–> 活着的对象copy 到survivor0
  3. 新生代 = Eden + 2个suvivor区
    1. YGC回收之后,大多数的对象会被回收,活着的进入s0
    2. 再次YGC,活着的对象eden + s0 -> s1
    3. 再次YGC,eden + s1 -> s0
    4. 年龄足够 -> 老年代 (15 CMS 6)
    5. s区装不下 -> 老年代
  4. 老年代
    1. 顽固分子
    2. 老年代满了FGC Full GC
  5. GC Tuning (Generation 分代算法)
    1. 尽量减少FGC(YGC+OGC) 产生stw 现象 停顿/卡段
    2. MinorGC = YGC
    3. MajorGC = FGC
5.常见的垃圾回收器

在这里插入图片描述

  1. Serial 年轻代 串行回收(单线程)
    停下所有线程–>回收垃圾–>继续执行
    Serial
  2. PS 年轻代 并行回收(多线程)

在这里插入图片描述

  1. ParNew 年轻代 配合CMS的并行回收
    在这里插入图片描述

  2. SerialOld 老年代 串行回收(单线程)

  3. ParallelOld 老年代 并行回收 (多线程)

  4. ConcurrentMarkSweep 老年代 并发的, 垃圾回收和应用程序同时运行,降低STW的时间(200ms)
    在这里插入图片描述

  5. G1(10ms)

  6. ZGC (1ms) PK C++

  7. Shenandoah

  8. Eplison

1.8默认的垃圾回收:PS + ParallelOld

6.JVM调优第一步,了解生产环境下的垃圾回收器组合
  • JVM的命令行参数参考:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/java.html

  • JVM参数分类

    标准: - 开头,所有的HotSpot都支持

    非标准:-X 开头,特定版本HotSpot支持特定命令

    不稳定:-XX 开头,下个版本可能取消

    -XX:+PrintCommandLineFlags
    使用参数
    -XX:+PrintFlagsFinal 最终参数值

    -XX:+PrintFlagsInitial 默认参数值

参考资料

  1. https://blogs.oracle.com/
    jonthecollector/our-collectors
  2. https://docs.oracle.com/javase/8/docs/technotes/tools/unix/java.html
  3. http://java.sun.com/javase/technologies/hotspot/vmoptions.jsp
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值