今天就跟大家聊聊有关如何解决JVM空闲堆内存不释放回OS的问题,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
在这些版本中,没有用于立即回收的显式选项,但是您可以通过进行设置来使GC一般更具侵略性,该设置-XX:GCTimeRatio=19 -XX:MinHeapFreeRatio=20 -XX:MaxHeapFreeRatio=30
将使其在GC后花费更多的CPU时间来收集和限制已分配但未使用的堆内存的数量。循环。
如果使用并发收集器,还可以将-XX:InitiatingHeapOccupancyPercent=N
N设置为一个较低的值,以使GC几乎连续运行并发收集,这将消耗更多的CPU周期,但会更快地缩小堆。通常这不是一个好主意,但是在某些类型的具有大量备用CPU内核但内存不足的计算机上,这是有道理的。
如果您使用的是G1GC,请注意,它仅使用jdk8u20获得了在堆中间退还未使用的块的功能,而早期版本只能在堆末尾返回块,这对可装载的块数量有很大的限制。收回。
如果您使用的收集器具有默认的暂停时间目标(例如CMS或G1),则您也可以放宽该目标,以对收集器施加更少的约束,或者您可以切换并行收集器,以在暂停时间上优先考虑占用空间。
为了验证是否发生收缩或诊断GC决定不收缩的原因,您可以使用GC Logging-XX:+PrintAdaptiveSizePolicy
来提供见解,例如,当JVM尝试为年轻一代使用更多内存以满足某些目标时。
添加了-XX:-ShrinkHeapInSteps
可用于更积极地应用由上一节中提到的选项引起的缩小的选项。相关的OpenJDK错误。
对于日志记录-XX:+PrintAdaptiveSizePolicy
已被替换为-Xlog:gc+ergo
引入了通过G1PeriodicGCInterval
(JEP 346)为G1GC启用即时内存释放的选项,但又以一些额外的CPU为代价。JEP还提到了Shenandoah和OpenJ9 VM中的类似功能。
如果您使用G1收集器并偶尔调用System.gc()(我每分钟执行一次),则Java将可靠地收缩堆并将内存返还给OS。
从Java 12开始,如果应用程序处于空闲状态,则G1会自动执行此操作。
我建议将这些选项与以上建议结合使用,以实现非常紧凑的驻留进程大小:
-XX:+UseG1GC -XX:MaxHeapFreeRatio=30 -XX:MinHeapFreeRatio=10
ZGC在13 Java中发布,它可以将未使用的堆内存返回给操作系统,请参阅链接
看完上述内容,你们对如何解决JVM空闲堆内存不释放回OS的问题有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。