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” 我想知道,当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是永久生成的大小的范围,它是非堆内存 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |