Docker环境下的JVM参数非定值配置 —— 筑梦之路

1. 命令行打印java进程信息

jinfo -flags 1

从进程信息中可以看到Xms和Xmx 的值

默认是Xms是16777216,即16M。Xmx是262144000,即256M

之前有种说法是,容器环境,由于java获取不到容器的内存限制,只能获取到服务器的配置。

以前确实有这种情况,但是java为了更好的使用容器环境,在Java 10 引入了 +UseContainerSupport(默认情况下启用),通过这个特性,可以使得JVM在容器环境分配合理的堆内存。

后来这个特性也合入了JDK8U191版本,在JDK8U191版本之后的java8也是可以获取容器的内存限制的。

2. UseContainerSupport

-XX:+UseContainerSupport允许JVM 从主机读取cgroup限制,例如可用的CPU和RAM,并进行相应的配置。这样当容器超过内存限制时,会抛出OOM异常,而不是杀死容器。 该特性在Java 8u191 +,10及更高版本上可用。

注意,在191版本后,-XX:MinMaxRAMFraction 被弃用,引入了-XX:MaxRAMPercentage,其值介于0.0到100.0之间,默认值为25.0。

3. 最佳实践

在应用的启动参数,设置 -XX:+UseContainerSupport,设置-XX:MaxRAMPercentage=75.0,这样为其他进程(debug、监控)留下足够的内存空间,又不会太浪费RAM。

你可能感兴趣的:(Java技术,linux系统运维,java,开发语言)