JVM修炼之路【12】- GC调优 、性能调优

上一篇中 我们详细讲了内存溢出 内存泄漏 还有相关的案例。 这篇博客中我们主要了解一下GC调优。

有些新手可能会有一点 疑问------ 这两者不是一回事吗??

其实说一回事 也没错 因为GC调优本质上还是针对 堆上的内存

只不过前面我们关注的侧重点在于 不合理的代码或者设计 会造成OOM 内存的不合适使用。

这一篇我们侧重于 垃圾回收器 做各种gc动作对于系统的影响,还有垃圾回收器的参数设置


GC调优的核心指标:

  • 吞吐量
  • 延迟

GC调优的主要工具

还是我们熟悉的内存监控工具 Prometheus+grafana

它也可以进行专业的GC监控

在线的GC日志分析网站:

优化JVM 基础参数

建议初始堆内存和最大堆内存一样大

调整每个线程的栈大小

根据不同的系统情况 我们来选择不同的垃圾回收器:

以下是 JDK 8 中一些常见的垃圾回收器及其适用场景:

年轻代垃圾回收器:

Serial GC:适用于内存小、单核CPU的环境,重视暂停时间的应用。

Parallel GC:适用于多核CPU的通用应用,注重吞吐量。

老年代垃圾回收器:

CMS GC:适用于对暂停时间要求较高的应用,如Web应用程序。在 CMS GC 中,年轻代使用并行垃圾回收器,而老年代使用CMS算法。

G1 GC:适用于大堆内存和对暂停时间敏感的应用程序。G1 GC 可以对整个堆进行更均衡的回收,避免了CMS GC 中的一些碎片问题,并且通常能够更好地控制暂停时间。


相关推荐
代码探秘者2 小时前
【Java集合】ArrayList :底层原理、数组互转与扩容计算
java·开发语言·jvm·数据库·后端·python·算法
星辰_mya3 小时前
锁优化高级策略:JVM 的“灵活执法”艺术
jvm·面试
语戚4 小时前
从 JVM 底层拆解:i++、++i、i+=1、i=i+1 的实现逻辑与坑点
java·开发语言·jvm·面试·自增·指令·虚拟机
你这个代码我看不懂4 小时前
JVM栈、方法区和堆内存
java·开发语言·jvm
花间相见5 小时前
【JAVA基础03】—— JDK、JRE、JVM详解及原理
java·开发语言·jvm
闻哥5 小时前
深入剖析Redis数据类型与底层数据结构
java·jvm·数据结构·spring boot·redis·面试·wpf
Engineer邓祥浩6 小时前
JVM学习笔记(2) 第一部分 走近java 第1章 走近java
jvm·笔记·学习
jinanmichael6 小时前
【SQL】掌握SQL查询技巧:数据分组与排序
java·jvm·sql
敲敲千反田6 小时前
深入了解JVM
jvm
AMoon丶7 小时前
C++基础-类、对象
java·linux·服务器·c语言·开发语言·jvm·c++