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

参考:

相关推荐
是宇写的啊8 分钟前
MyBaties
java·开发语言·mybatis
钝挫力PROGRAMER11 分钟前
程序中事件机制的实现
java·后端·python·软件工程
程序员威哥15 分钟前
Java调用YOLO模型性能优化实战:CPU/GPU加速与内存优化全指南
java·人工智能·后端
郝开19 分钟前
Docker Compose 本地环境搭建:独立 Compose + 共享网络 + .env 统一管理(架构设计篇)
网络·docker·容器
岳来19 分钟前
docker 容器文件 hostconfig.json 和 config.v2.json 的区别
docker·容器·hostconfig.json·config.v2.json
Xpower 1721 分钟前
OpenClaw Token 优化的技术方案与实践:OpenSpace 自进化 Skill 引擎
java·开发语言·人工智能
杨凯凡21 分钟前
【022】JVM 运行时数据区与对象创建
java·jvm·后端
阿Y加油吧28 分钟前
算法二刷复盘:LeetCode 79 单词搜索 & 131 分割回文串(Java 回溯精讲)
java·算法·leetcode
-凌凌漆-31 分钟前
【QML】qml和C++中同时使用单例模式
java·c++·单例模式
那个失眠的夜32 分钟前
RESTful 语法规范 核心注解详解
java·spring·mvc·mybatis