本文主要是介绍K8S时代的JAVA_OPTS参数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
问题
最近Spring要住到k8s的pod里面去了,导致原来的JAVA_OPTS配置方式,不能那么大开大合了。这里假设使用的Java 8.
原来的JAVA_OPTS参数:
JAVA_OPTS="-server -Xms6g -Xmx6g -XX:+UseG1GC -XX:MaxGCPauseMillis=20 -XX:InitiatingHeapOccupancyPercent=35 -XX:+ExplicitGCInvokesConcurrent -Djava.awt.headless=true"
新JAVA_OPTS参数
JAVA_OPTS="-server -XX:MinRAMPercentage=50.0 -XX:MaxRAMPercentage=80.0 -XX:+UseG1GC -XX:MaxGCPauseMillis=20 -XX:InitiatingHeapOccupancyPercent=35 -XX:+ExplicitGCInvokesConcurrent -Djava.awt.headless=true"
这里比较难以理解的是如下参数:
-XX:InitiatingHeapOccupancyPercent=35
:这里意思但堆内存占到35%时,开始进行标记,以便触发并发GC。如果JVM支持-XX:+G1UseAdaptiveIHOP
设置,就没有必要研究这个参数的设置了,但是,-XX:+G1UseAdaptiveIHOP
是在JDK 9之后才支持的。-XX:MinRAMPercentage=50.0 -XX:MaxRAMPercentage=80.0
:这个意思比较直白,最小使用物理内存的50%,最大使用物理内存的80%。但是,这个在容器时代,需要JVM支持-XX:+UseContainerSupport
设置。-Djava.awt.headless=true
:表示开启JVM无头模式(没有GUI),就是后台Java是一个纯后台存储,没有一点点前端的东西。如页面动态生成之类的东西。
参考:
- 容器环境的JVM内存设置最佳实践
- JVM Tuning with G1 GC
- Using Headless Mode in the Java SE Platform
- 你假笨JVM参数 - 006 ExplicitGCInvokesConcurrent
这篇关于K8S时代的JAVA_OPTS参数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!