1.Dockerfile中想要设置HeapDumpPath生成的内存溢出文件后面自动拼接时间,不能设置到JAVA_OPTS中,那样不生效,还会因为有空格,导致+%Y%m%d%H%M%S).hprof被识别为main class的名字而报错,错误设置如下:
部分Dockerfile配置
ENV LANG=C.UTF-8
ENV LOG_HOME=/log
ENV JAVA_OPTS="-Xms8m -Xmx64m -XX:+HeapDumpOnOutOfMemoryError \"-XX:HeapDumpPath=$LOG_HOME/heap-$(date +%Y%m%d%H%M%S).hprof\""
ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar -Dspring.profiles.active=dev /my/servera.jar" ]
直接在ENTRYPOINT 拼接到java 命令后面可以正确生效,正确配置如下:
ENV LANG=C.UTF-8
ENV LOG_HOME=/log
ENV JAVA_OPTS="-Xms8m -Xmx64m -XX:+HeapDumpOnOutOfMemoryError"
ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS \"-XX:HeapDumpPath=$LOG_HOME/heap-$(date +%Y%m%d%H%M%S).hprof\" -Djava.security.egd=file:/dev/./urandom -jar -Dspring.profiles.active=dev /my/servera.jar" ]