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 中的一些碎片问题,并且通常能够更好地控制暂停时间。


相关推荐
LucaJu36 分钟前
一次 OOM 线上排查实录
java·jvm·oom·内存溢出
大大杰哥1 小时前
温故知新:Java 线程创建方式的演进与总结
java·开发语言·jvm
网络工程小王2 小时前
【LangGraph 状态持久化(Checkpoint)详解】学习笔记
jvm·人工智能·笔记·langchain
Devin~Y2 小时前
电商AIGC智能客服面试:JVM调优、Spring Cloud微服务、Redis缓存、Kafka消息、K8s观测与RAG落地
java·jvm·spring boot·redis·spring cloud·kafka·kubernetes
2301_769340672 小时前
HTML函数运行时触控屏失灵是硬件故障吗_输入层兼容性测试【详解】
jvm·数据库·python
2301_809204706 小时前
bootstrap怎么实现鼠标悬停切换图片预览功能
jvm·数据库·python
weixin_4440129314 小时前
c++如何将std--vector直接DUMP到二进制文件_指针地址直写【附代码】
jvm·数据库·python
woxihuan12345614 小时前
Go语言中--=运算符详解:位右移赋值操作的原理与应用
jvm·数据库·python
m0_6908258215 小时前
如何备份被破坏的数据表_强制跳过错误的导出尝试
jvm·数据库·python
m0_7335654615 小时前
JavaScript中Reflect-ownKeys获取所有键名的优势
jvm·数据库·python