当前位置:网站首页>JVM Tuning-GC Fundamentals and Tuning Key Analysis
JVM Tuning-GC Fundamentals and Tuning Key Analysis
2022-08-04 15:37:00 【Feifei Technology House】
1.写在前面
前面分享了 JVM调优原则和原理分析 ,详情可查看:这里
基于该文章,we are generally right JVM have a general understanding,同时我们知道了 JVM调优原则 (JVM优化是不得已的手段)
对 调优基础知识 (head堆,垃圾回收器)等知识点,有一个初步的认识.
So today we continue to share: 垃圾回收算法 ,和 Key Metrics for Tuning ,等内容.
2.JVM的GC基本原理
2.1 什么是垃圾?
在内存中 没有被引用的对象 就是垃圾(A request creates many objects in memory,These objects don't go away on their own,必须进行 垃圾回收 ,当然 垃圾回收器 是jvm自己提供的.)
(特别注意:高并发的场景下,In particular, a large number of objects are created in memory,The memory occupied by these objects must be released in time,Otherwise, the program performance will be affected)
an object reference disappeared,Then the object becomes 垃圾 ;Therefore this object must be 垃圾回收器 回收;
那说到这里,we will have doubts,how to judge an object,will be garbage?
别急,且听哥们一一道来!!!接着往下.
2.2 how to find this junk?
Jvm中有 2 A scheme for finding junk objects:
1 、引用计数算法
2 、根可达算法 ----- hotspot垃圾回收器 use this algorithm
1) 引用计数算法:
By reference counting method,find this garbage:
当这个对象引用都消失了,消失一个计数减一,当引用都消失了,计数就会变为0.此时这个对象就会变成垃圾.
这样,会存在问题:
There are three main reference relationships in heap memory::
- single reference
- 循环引用
- 无引用
由此可见,Reference counting algorithm can't solve the problem of a circular reference.为了解决这个问题,Javaroot reachability analysis algorithm.
循环引用,使用这个算法,是无法解决的.
That leads to another algorithm: 根可达算法
2) 根可达算法:
hotspotAlgorithms of the main garbage collectors currently in use,Because reference counting cannot solve the problem of circular reference counting.
The basic idea of root reachability analysis algorithm is: 通过一系列名为"GC roots"的对象作为起始点,从这个被称为GC roots的对象开始,向下搜索,如果一个对象到GC roots没有任何引用链相连时,说明此对象不可用.
That is, given a reference to a collection as 根 出发,通过引用关系遍历对象图,能够遍历到的(可到达)object is judged to be 存活 ,If not, it is naturally judged as 死亡 .
所谓的"GC roots"object starting point,或者说tracing GC的"根集合"就是一组必须活跃的引用.
通过 根可达算法 ,We have found the garbage object,接下来,just remove the trash.
How to remove garbage?这里JVM提供3种算法.且听哥们一一道来!!!
2.3 如何清除垃圾?
JVM提供 3 种方法,清除垃圾对象
- Mark-Sweep 标记清除算法
- Copying 拷贝算法
- Mark-Compact 标记压缩算法
Mark-Sweep 标记清除算法
- 缺点:Fragmentation of memory storage space
Copying 拷贝算法
为了解决效率问题,Copying The copy algorithm divides the available memory into two equal-sized blocks by capacity,每次只使用其中一块.当这一块的内存用完了,就将还存活着的对象复制到另外一块上面,然后再把已使用过的内存空间一次清理掉.这样使得每次都是对整个半区进行内存回收,内存分配时也就不用考虑内存碎片等复杂情况,只要移动堆顶指针,按顺序分配内存即可,实现简单,运行高效.只是这种算法的代价是将内存缩小为了原来的一半.
- 优点:没有碎片化,All useful spaces are connected together,All of the free space are connected together
- 缺点:存在空间浪费.
Mark-Compact 标记压缩算法
标记压缩算法,把存活对象拷贝到可回收的空间,然后把存活对象空间进行压缩,串联起来,Concatenate unused object space,form a contiguous memory space,这样就不会有碎片.
- 缺点:性能较低,因为除了拷贝对象以外,还需要对象内存空间进行压缩,所以性能较低.
2.4 用什么清除垃圾
有 7 种不同的垃圾回收器,它们分别用于不同分代的垃圾回收.
- 新生代回收器:Serial、ParNew、Parallel Scavenge
- 老年代回收器:Serial Old、Parallel Old、CMS
- 整堆回收器:G
There is a line between the two garbage collectors to indicate that they can be used together,可选的搭配方案如下:
新生代 | 老年代 |
---|---|
Serial | Serial Old |
Serial | CMS |
ParNew | Serial Old |
ParNew | CMS |
Parallel Scavenge | Serial Old |
Parallel Scavenge | Parallel Old |
G1 | G1 |
3.Tuning key metrics
The ultimate purpose of tuning is for application use The smallest hardware consumption to carry a larger 吞吐量
3.1 吞吐量
One of the important indicators,吞吐量是衡量系统在单位时间里面完成的工作数量.吞吐量需求通常忽略延迟或者响应时间.通常情况下,提升吞吐量需要以系统响应变慢和更多内存消耗作为代价.
- TPS:每秒事务数
- Throughput:吞吐量=运行用户代码时间/(运行用户代码时间+垃圾收集时间),虚拟机总共运行了 100 分钟,其中垃圾收集花掉 1 分钟,那吞吐量就是99%.
3.2 Latency or response time
延迟或者响应时间是衡量应用从接收到一个任务到完成这个任务消耗的时间.一个延迟或者响应时间的需求需要忽略吞吐量.通常来讲,Improving application response time requires lower throughput or higher application memory consumption.
Latency or response time example:"例如系统处理一个HTTP请求需要200ms,这个200ms就是系统的响应时间."
3.3 内存占用
内存占用是衡量应用消耗的内存,这个内存占用是指应用在运行在某一个吞吐量、延迟以及可用性和易管理性指标下的内存消耗,内存占用是通常描述为应用运行的时候Java堆的大小或者总共需要消耗内存.
通常情况下,通过增加Java堆的大小以增加应用内存占用可以提升吞吐量或者减少延迟,或者两者兼具.当应用可用的内存减少的时候,吞吐量和延迟通常会受到损失.在给定内存的情况下,应用占用的内存可以限制应用的实例数(这个会影响可用性).
Example of memory usage requirement:“这个应用会单独运行在一个8G的系统上面或者多出 3 个应用实例运行在一个24G的应用系统上面.”
好了,以上就是我个人的经验的分享了.
边栏推荐
猜你喜欢
随机推荐
MVCC实现过程
我在羊毛和二手群里报复性消费
C端折戟,转战B端,联想的元宇宙梦能成吗?
成员变量与局部变量的区别有哪些
Redis-哨兵模式
I/O stream summary
Semaphore 基本原理
numpy入门详细代码
C# 局部函数与事件
饿了么智能头盔专利获授权,进一步提升骑手安全保障
保证通信的机制有哪些
leetcode: 251. Expanding 2D Vectors
我说MySQL联合索引遵循最左前缀匹配原则,面试官让我回去等通知
《2022 年上半年全球独角兽企业发展研究报告》发布——DEMO WORLD世界创新峰会圆满落幕
Xi'an Zongheng Information × JNPF: Adapt to the characteristics of Chinese enterprises, fully integrate the cost management and control system
爬虫小白笔记(昨天的对于注意解析数据的补充)
leetcode: 250. Count subtrees of equal value
Codeforces Round #811 A~F
HarePoint Analytics for SharePoint Online
什么是 DevOps?看这一篇就够了!