K8S时代的JAVA_OPTS参数

问题

最近Spring要住到k8s的pod里面去了,导致原来的JAVA_OPTS配置方式,不能那么大开大合了。这里假设使用的Java 8.

原来的JAVA_OPTS参数:

bash 复制代码
JAVA_OPTS="-server -Xms6g -Xmx6g -XX:+UseG1GC -XX:MaxGCPauseMillis=20 -XX:InitiatingHeapOccupancyPercent=35 -XX:+ExplicitGCInvokesConcurrent -Djava.awt.headless=true"

新JAVA_OPTS参数

bash 复制代码
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是一个纯后台存储,没有一点点前端的东西。如页面动态生成之类的东西。

参考:

相关推荐
peiwang24514 小时前
Linux系统中CoreDump的生成与调试
java·linux·开发语言
顾漂亮14 小时前
Redis深度探索
java·redis·后端·spring·缓存
努力也学不会java14 小时前
【Spring】Spring事务和事务传播机制
java·开发语言·人工智能·spring boot·后端·spring
hookserver14 小时前
企业微信聚合应用系统,ipad协议接口
java·http·微信·企业微信·ipad
学习编程的Kitty14 小时前
JavaEE初阶——多线程(2)线程的使用
java·开发语言·java-ee
counting money14 小时前
JAVAEE阶段学习指南
java·开发语言
大大大大物~14 小时前
数据结构之HashMap(容器)
java·数据结构·容器
原来是好奇心14 小时前
告别if-else!使用策略模式优雅处理多种MQTT消息类型
java·mqtt·设计模式·策略模式·emqx
IT·陈寒14 小时前
从 Spring 到 SpringBoot,再到 SpringAI:框架的进化与思考
java·spring boot·spring
spionbo14 小时前
C++中的位运算符:与、或、异或详解
java