参考资料:Best Practices: Java Memory Arguments for Containers - DZone Java
有三种方式设置最大堆内存大小:
1. -Xmx
2. -XX:MaxRAMFraction, -XX:MinRAMFraction
3.-XX:MaxRAMPercentage, -XX:MinRAMPercentage
这种方式很直接,适用于所有JAVA版本:
java -Xmx512m -jar app.jar
设置最大堆内存大小为512M。
只适用于 Java8-131 -190版本(本人未测试该方法)
java -XX:MaxRAMFraction=2 -jar app.jar
按照开头文章中介绍,MaxRAMFraction=2代表将使用容器总内存的1/2作为JVM的最大堆内存。
适用于Java8-191以上版本(已验证测试)
java -XX:MaxRAMPercentage=70.0 -jar app.jar
MaxRAMPercentage=70.0代表将使用容器的resources.limit.memory值的70%作为JVM的最大堆内存(注意70必须加.0,否则JVM将启动失败:日志里报Improperly specified VM option错误)
Dockerfile中设置MaxRAMPercentage=70.0
![]()
测试JDK版本:1.8小版本号为275:

(另:在不使用MaxRAMPercentage参数时,该版本JDK将默认使用1/4的resources.limit.memory作为JVM的堆内存大小)
k8s deployment中resource设置:

JVM堆内存大小:

1.5G * 1024 * 70% 约等于1076MB,符合预期结果。
====================================================================
如有不对的理解,欢迎指正~