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

参考:

相关推荐
知其然亦知其所以然13 分钟前
RAG 结果太水?用 RRF + Reranker 重排,效果翻倍提升!
java·后端·llm
SimonKing15 分钟前
吊打面试官系列:Spring为什么不推荐使用字段依赖注入?
java·后端·架构
魔镜魔镜_谁是世界上最漂亮的小仙女22 分钟前
java-集合
java·后端·程序员
真实的菜24 分钟前
消息队列高级特性与原理:解锁分布式系统的底层逻辑
java
若水不如远方25 分钟前
java范型
java
凌辰揽月28 分钟前
Web后端基础(基础知识)
java·开发语言·前端·数据库·学习·算法
lifallen33 分钟前
深入浅出 Arrays.sort(DualPivotQuicksort):如何结合快排、归并、堆排序和插入排序
java·开发语言·数据结构·算法·排序算法
长安不见35 分钟前
背景知识: 理解LimitLatch背后的AQS
java
小吕学编程38 分钟前
策略模式实战:Spring中动态选择商品处理策略的实现
java·开发语言·设计模式
weixin_4383354044 分钟前
Spring Boot实现接口时间戳鉴权
java·spring boot·后端