Java GC概念:CMSInitiatingOccupancyFraction

前端之家收集整理的这篇文章主要介绍了Java GC概念:CMSInitiatingOccupancyFraction前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我已经配置了以下内存选项:

导出MEM_OPTS =“ – Xmx2560m -Xms2560m -XX:NewSize = 786m -XX:MaxNewSize = 786m -XX:UseTLAB -XX:MaxPermSize = 512m”

GC参数如下:

export GC1_OPTS =“ – XX:UseConcMarkSweepGC -XX:UseParNewGC -XX:CMSInitiatingOccupancyFraction = 50 -XX:CMSPermGenSweepingEnabled -XX:CMSClassUnloadingEnabled -XX:CMSParallelRemarkEnabled -XX:UseAdaptiveGCBoundary”
export GC2_OPTS =“ – XX:ExplicitGCInvokesConcurrent”

我想知道,当CMS将运行时,它将运行在2560 MB的50%之后,否则会在512 MB内存的50%之后运行.

什么是概念?

我的总记忆将是= 2560 786 512 MB ….对吧?或“-XX:NewSize = 786m -XX:MaxNewSize = 786m”用于NON堆.请解释该概念.

解决方法

都不是.老一代的占有率达到50%后,有资格运行,旧世代的大小减去新一代的大小:2560m-786m = 1792m,这将是后老一代达到896m.但这并不总是唯一的参数.您可能想要添加-XX:UseCMSInitiatingOccupancyOnly如果您希望它成为唯一的参数(尽管在我的经验中,CMS实际上触发阈值,即使没有).

总结:

> -Xmx是总堆内存> -XX:NewSize / -XX:MaxNewSize是该堆内新一代大小的范围>不同的是旧一代的大小范围> -XX:PermSize / -XX:MaxPermSize是永久生成的大小的范围,它是非堆内存

原文链接:https://www.f2er.com/java/121921.html

猜你在找的Java相关文章