使用Maven构建我的Spring-boot映像时,我现在在Dockerfile中执行此操作。 Maven将下载所有依赖项,然后编译我的文件。这需要相当长的时间。
如何通过docker-compose(Dockerfile)指定构建过程重用我的“Windows10 Home”Maven存储库?因此,(新)下载的数量很少。我的开发环境:我使用Docker快速启动终端,所以使用docker-machine。
这是我的docker-compose.yml文件的一部分:
version: '3'
services:
spring-boot-app:
image: spring-boot-image
build:
context: ./
dockerfile: Dockerfile
depends_on:
- mysql-docker-container
ports:
- 8087:8080
volumes:
- $HOME/.m2/repository:/root/.m2/repository
- /data/spring-boot-app
我的Dockerfile是:
FROM java:8
FROM maven:alpine
WORKDIR /app
COPY . /app
RUN mvn -v
RUN mvn clean install -DskipTests
EXPOSE 8080
LABEL maintainer=“[email protected]”
ADD ./target/spring-boot-example-0.0.1-SNAPSHOT.jar /developments/
ENTRYPOINT ["java","-jar","/developments/spring-boot-example-0.0.1-SNAPSHOT.jar"]
@Jack Gore - 非常感谢你给我指路。我看过这篇文章,但还没有确定的答案。在完成所有单独答案后,该信息为我提供了症状的答案以及如何解决类似问题的见解。
解答:通过Dockerfile,您可以通过一个或多个后续图像层构建最终图像。为了防止步骤每次重新下载依赖项,您可以为“下载世界”的依赖项创建一个图像层。只有在pom.xml文件中的依赖项发生更改时才会重新下载。
为此,您需要在两个构建步骤中拆分Dockerfile:首先复制pom.xml文件并构建它。这将创建一个包含所有依赖项的图像层。作为构建应用程序的第二步。
FROM java:8
FROM maven:alpine
# image layer
WORKDIR /app
ADD pom.xml /app
RUN mvn verify clean --fail-never
# Image layer: with the application
COPY . /app
RUN mvn -v
RUN mvn clean install -DskipTests
EXPOSE 8080
ADD ./target/your.jar /developments/
ENTRYPOINT ["java","-jar","/developments/your.jar"]
然后,您将获得以下构建方案:
分离图像层的影响通过number of very short videos显示。
这种构建方式的缺点当然是最终(生产)图像包含的不仅仅是应用程序。不仅JAR在其中,而且还有许多依赖项。
如何解决这个图像太大了:
对于我的情况,这是最好的选择。您可以自动执行此过程并保持较低的图像大小。