目录
在 Docker 容器中部署 Java 微服务时,合理配置 JVM(Java 虚拟机)的内存限制是确保应用稳定运行的关键。由于 JVM 默认无法感知 Docker 设置的内存限制,这可能导致内存溢出(OOM)和容器崩溃。本文将详细介绍如何在 Docker 容器中部署 Java 微服务 JAR 包,并合理配置内存限制。
一、问题背景
在 Docker 容器中运行 Java 应用时,JVM 默认会根据宿主机的总内存来分配堆内存,而不会感知容器的内存限制。例如,如果宿主机有 8GB 内存,JVM 可能会默认分配 2GB 作为堆内存。然而,如果容器的内存限制仅为 512MB,JVM 分配的堆内存将远超容器的可用内存,导致容器被内核终止。
二、解决方案
(一)显式设置 JVM 堆内存大小
最直接的方法是在 Java 启动参数中显式设置堆内存的最大值(-Xmx
)和初始值(-Xms
)。例如,如果容器的内存限制为 512MB,可以将 JVM 的堆内存设置为 256MB:
bash复制
docker run -m 512M -d --name my-java-app openjdk:11-jdk java -Xmx256m -Xms128m -jar myapp.jar
(二)让 JVM 感知容器资源限制
从 Java SE 8u131 版本开始,JVM 引入了新的参数,使其能够感知 Docker 容器的内存限制:
-
-XX:UnlockExperimentalVMOptions
:解锁实验性 VM 选项。 -
-XX:UseC