首页 > 其他分享 >JVM调优-GC基本原理和调优关键分析

JVM调优-GC基本原理和调优关键分析

时间:2022-10-05 10:31:31浏览次数:62  
标签:对象 引用 回收 算法 调优 GC 内存 JVM 垃圾

1.写在前面

今天我们分享一下:垃圾回收算法,和调优的关键指标,等内容。

JVM调优-GC基本原理和调优关键分析_垃圾回收器

2.JVM的GC基本原理

2.1 什么是垃圾?

在内存中没有被引用的对象就是垃圾(一次请求会在内存中创建出很多的对象,这些对象不会自己消失,必须进行垃圾回收,当然垃圾回收器是jvm自己提供的。)

(特别注意:高并发的场景下,内存中尤其会创建海量的对象,这些对象所占用的内存必须及时被释放,否则影响程序性能)

一个对象引用消失了,那么这个对象就变成垃圾;因此这个对象必须被垃圾回收器回收;

JVM调优-GC基本原理和调优关键分析_响应时间_02

那说到这里,我们就会有疑问了,怎样判断一个对象,将会成为垃圾呢?

别急,且听哥们一一道来!!!接着往下。

2.2 如何找到这个垃圾?

Jvm中有 2 种寻找垃圾对象的方案:

1 、引用计数算法

2 、根可达算法 ----- hotspot垃圾回收器都是使用这个算法

1) 引用计数算法:

通过引用计数方法,找到这个垃圾:

JVM调优-GC基本原理和调优关键分析_响应时间_03

当这个对象引用都消失了,消失一个计数减一,当引用都消失了,计数就会变为0.此时这个对象就会变成垃圾。

这样,会存在问题:

在堆内存中主要的引用关系有如下三种:

  • 单一引用
  • 循环引用
  • 无引用

JVM调优-GC基本原理和调优关键分析_引用计数_04

由此可见,引用计数算法不能解决循环引用问题。为了解决这个问题,Java使用了根可达分析算法。

循环引用,使用这个算法,是无法解决的。

那就引出了另外一种算法:根可达算法

2) 根可达算法:

hotspot 目前使用的主要的垃圾回收器的算法,因为引用计数无法解决循环引用计数的问题。

根可达分析算法的基本思想是: 通过一系列名为"GC roots"的对象作为起始点,从这个被称为GC roots的对象开始,向下搜索,如果一个对象到GC roots没有任何引用链相连时,说明此对象不可用。

也即给定一个集合的引用作为出发,通过引用关系遍历对象图,能够遍历到的(可到达)对象就被判定为存活,没有则自然被判定为死亡

所谓的"GC roots"对象起始点,或者说tracing GC的"根集合"就是一组必须活跃的引用。

通过根可达算法,我们已经找出垃圾对象了,接下来,就是清除垃圾。

如何清除垃圾呢?这里JVM提供3种算法。且听哥们一一道来!!!

JVM调优-GC基本原理和调优关键分析_引用计数_05

2.3 如何清除垃圾?

JVM提供 3 种方法,清除垃圾对象

  1. Mark-Sweep 标记清除算法
  2. Copying 拷贝算法
  3. Mark-Compact 标记压缩算法

Mark-Sweep 标记清除算法

JVM调优-GC基本原理和调优关键分析_垃圾回收器_06

  • 缺点:内存存储空间碎片化

Copying 拷贝算法

为了解决效率问题,Copying 拷贝算法将可用内存按容量划分为大小相等的两块,每次只使用其中一块。当这一块的内存用完了,就将还存活着的对象复制到另外一块上面,然后再把已使用过的内存空间一次清理掉。这样使得每次都是对整个半区进行内存回收,内存分配时也就不用考虑内存碎片等复杂情况,只要移动堆顶指针,按顺序分配内存即可,实现简单,运行高效。只是这种算法的代价是将内存缩小为了原来的一半。

  • 优点:没有碎片化,所有的有用的空间都连接在一起,所有的空闲空间都连接在一起
  • 缺点:存在空间浪费。

Mark-Compact 标记压缩算法

JVM调优-GC基本原理和调优关键分析_响应时间_07

标记压缩算法,把存活对象拷贝到可回收的空间,然后把存活对象空间进行压缩,串联起来,把未使用的对象空间串联起来,组成连续的内存空间,这样就不会有碎片。

  • 缺点:性能较低,因为除了拷贝对象以外,还需要对象内存空间进行压缩,所以性能较低。

2.4 用什么清除垃圾

有 7 种不同的垃圾回收器,它们分别用于不同分代的垃圾回收。

  • 新生代回收器:Serial、ParNew、Parallel Scavenge
  • 老年代回收器:Serial Old、Parallel Old、CMS
  • 整堆回收器:G

两个垃圾回收器之间有连线表示它们可以搭配使用,可选的搭配方案如下:

新生代

老年代

Serial

Serial Old

Serial

CMS

ParNew

Serial Old

ParNew

CMS

Parallel Scavenge

Serial Old

Parallel Scavenge

Parallel Old

G1

G1

3.调优关键指标

调优的最终目的都是为了应用程序使用 最小的硬件 消耗来承载更大的 吞吐量

3.1 吞吐量

重要指标之一,吞吐量是衡量系统在单位时间里面完成的工作数量。吞吐量需求通常忽略延迟或者响应时间。通常情况下,提升吞吐量需要以系统响应变慢和更多内存消耗作为代价。

  • TPS:每秒事务数
  • Throughput:吞吐量=运行用户代码时间/(运行用户代码时间+垃圾收集时间),虚拟机总共运行了 100 分钟,其中垃圾收集花掉 1 分钟,那吞吐量就是99%。

3.2 延迟或响应时间

延迟或者响应时间是衡量应用从接收到一个任务到完成这个任务消耗的时间。一个延迟或者响应时间的需求需要忽略吞吐量。通常来讲,提升应用的响应时间需要以更低吞吐量或提高应用的内存消耗。

延迟或者响应时间例子:"例如系统处理一个HTTP请求需要200ms,这个200ms就是系统的响应时间。"

3.3 内存占用

内存占用是衡量应用消耗的内存,这个内存占用是指应用在运行在某一个吞吐量、延迟以及可用性和易管理性指标下的内存消耗,内存占用是通常描述为应用运行的时候Java堆的大小或者总共需要消耗内存。

通常情况下,通过增加Java堆的大小以增加应用内存占用可以提升吞吐量或者减少延迟,或者两者兼具。当应用可用的内存减少的时候,吞吐量和延迟通常会受到损失。在给定内存的情况下,应用占用的内存可以限制应用的实例数(这个会影响可用性)。

内存占用需求例子:“这个应用会单独运行在一个8G的系统上面或者多出 3 个应用实例运行在一个24G的应用系统上面。”

标签:对象,引用,回收,算法,调优,GC,内存,JVM,垃圾
From: https://blog.51cto.com/u_15733182/5732321

相关文章

  • jvm 调优常用参数
    -Xms50M  最小堆内存-Xmx50M  最大堆内存-XX:+UseG1GC使用G1垃圾收集器-XX:MaxGCPauseMillis=6最大停顿时间毫秒-XX:+PrintGCDetails 打印GC日志-XX:ConcGCThrea......
  • 【SpringCloud】扩展——DependencyManagement和Dependencies
     Maven使用 dependencyManagement 和 dependencies 进行包的管理,它们有什么联系和区别呢? dependencyManagement 里只是在父项声明依赖; dependencies 引入依赖,并......
  • JVM
    是什么JavaVirtualMachine翻译为Java虚拟机为什么提供了JAVA程序的运行环境,保证了JAVA运行与平台无关的特性定义了JVM规范,保证了JAVA代码的统一性和规范性JV......
  • 【SpringCloud】初始之——新建父工程
    环境IDEA2018.2.4JDK1.8.0_191Maven3.5.2步骤新建Maven项目。输入项目名称。 添加键值对。使得能够快速生成项目。 点击【Next】,直到完成项目创建。......
  • java的jvm堆中的内存泄露和内存溢出的概念以及区别【杭州多测师】【杭州多测师_王sir
    一、什么是内存溢出和内存泄露内存泄漏(memoryleak):是指程序在申请内存后,无法释放已申请的内存空间,导致系统无法及时回收内存并且分配给其他进程使用。通常少次数的内存无......
  • gcc学习
    GCC在第二章学习gcc时,感觉还是有比较多的东西没有理解完全,在此写下博客,来接续总结归纳以下~编写模式-E:仅执行编译预处理
-S:将C代码转换为汇编代码
-c:仅执行编译操......
  • golang GC原理
    一、堆栈栈(heap):由操作系统自动分配释放。一般函数内部执行中声明的变量,函数返回时直接释放,不会引起垃圾回收,对性能无影响堆(stack):一般由程序员分配释放,若程序......
  • 知识图谱顶会论文(ACL-2022) CAKE:用于多视图KGC的可扩展常识感知框架
    CAKE:用于多视图KGC的可扩展常识感知框架.pdf论文地址:CAKE:ScalableCommonsense-AwareFrameworkForMulti-ViewKnowledgeGraphCompletionCAKE:用于多视图知KGC的可扩......
  • [AGC041D] Problem Scores
    StOKubic神发现主要限制在第三个限制,考虑变形一下限制要求,问题转化为要求序列的\(k=\lfloor\dfrac{n}{2}\rfloor\),的前\(k+1\)项的和,大于后\(k\)项的和。动......
  • 浅谈JVM模型以及Class文件是怎么被加载的
    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档@目录前言一.什么是JVM二、JVM类加载机制1.类加载的概念2.类加载具体流程3.类加载器4.双亲委派机制4.1......