Java 优化springboot jar 内存 年轻代和老年代的比例 减少垃圾清理耗时 如调整 -XX:NewRatio

-XX:NewRatio 是 Java Virtual Machine (JVM) 的一个选项,用于调整 年轻代(Young Generation)和 老年代(Old Generation)之间的内存比例。

1. 含义

XX:NewRatio=N 用于指定 老年代 与 年轻代 的内存比例。

N 的含义:

老年代内存占整个堆内存的比例为 (N / (N + 1))。

年轻代内存占整个堆内存的比例为 (1 / (N + 1))。

例如:

-XX:NewRatio=3:

老年代占堆内存的 3/4。

年轻代占堆内存的 1/4。

2. 默认值

HotSpot JVM 中,NewRatio 的默认值为 2:

老年代占堆内存的 2/3。

年轻代占堆内存的 1/3。

3. 使用场景

根据应用程序的内存分配需求,可以调整 NewRatio:

对象生命周期较长的应用(如服务器应用):

推荐使用较高的 NewRatio(如 3 或更高),将更多的堆内存分配给老年代。

对象生命周期较短的应用(如计算密集型应用):

推荐使用较低的 NewRatio(如 2 或更低),将更多的堆内存分配给年轻代。

4. 示例

启动参数设置

bash 复制代码
java -XX:NewRatio=3 -Xms512m -Xmx512m -jar myapp.jar

堆内存分布计算

假设堆大小为 512 MB 且 -XX:NewRatio=3:

年轻代:512 MB / (3 + 1) = 128 MB

老年代:512 MB - 128 MB = 384 MB

5. 注意事项

与其他 GC 选项的关系:

如果使用 G1 GC(-XX:+UseG1GC),NewRatio 可能不起作用,因为 G1 GC 会根据应用动态调整堆内存划分。

对象分配失败的影响:

如果年轻代内存分配太小,可能导致频繁的 Minor GC。

如果老年代内存分配太小,可能导致频繁的 Major GC 或 Full GC。

建议:

监控应用内存使用情况(通过工具如 jstat、VisualVM 或 Java Mission Control),根据实际需要调整。

6. 常见调优组合

初始堆大小和最大堆大小:

bash 复制代码
-Xms512m -Xmx1024m

年轻代内存固定大小(替代 NewRatio):

bash 复制代码
-XX:NewSize=128m -XX:MaxNewSize=128m

GC 日志分析:

bash 复制代码
-Xlog:gc*:gc.log

通过合理调整 NewRatio 和其他 JVM 参数,可以有效优化 Java 应用的内存使用和 GC 行为!

相关推荐
麦兜*1 小时前
Spring Boot 企业级动态权限全栈深度解决方案,设计思路,代码分析
java·spring boot·后端·spring·spring cloud·性能优化·springcloud
ruan1145142 小时前
MySQL4种隔离级别
java·开发语言·mysql
Hellyc6 小时前
基于模板设计模式开发优惠券推送功能以及对过期优惠卷进行定时清理
java·数据库·设计模式·rocketmq
lifallen6 小时前
Paimon LSM Tree Compaction 策略
java·大数据·数据结构·数据库·算法·lsm-tree
hdsoft_huge6 小时前
SpringBoot 与 JPA 整合全解析:架构优势、应用场景、集成指南与最佳实践
java·spring boot·架构
百锦再7 小时前
详细解析 .NET 依赖注入的三种生命周期模式
java·开发语言·.net·di·注入·模式·依赖
程序员的世界你不懂7 小时前
基于Java+Maven+Testng+Selenium+Log4j+Allure+Jenkins搭建一个WebUI自动化框架(2)对框架加入业务逻辑层
java·selenium·maven
有没有没有重复的名字8 小时前
线程安全的单例模式与读者写者问题
java·开发语言·单例模式
张先shen9 小时前
Elasticsearch RESTful API入门:基础搜索与查询DSL
大数据·spring boot·elasticsearch·搜索引擎·全文检索·restful
慕木兮人可9 小时前
Docker部署MySQL镜像
spring boot·后端·mysql·docker·ecs服务器