我是一个新的docker.Plaining:自动化构建过程和创建docker镜像,并存储在dockerHub.这整个构建过程中,我想配置在DockerFile。
以下是我的Docker文件
# the first stage of our build will use a maven 3.6.1 parent image
FROM maven:3.6.1-jdk-8-alpine AS MAVEN_BUILD
# copy the pom and src code to the container
WORKDIR ./
COPY ./ ./
# package our application code
RUN mvn clean package -X
FROM java:8-jdk-alpine
WORKDIR ./
EXPOSE 8080
ENTRYPOINT ["java", "-jar", "config-consumer-0.0.1-SNAPSHOT.jar"]
从Docker中心运行自动化构建的构建报告。
figuring mojo 'org.sprin
gframework
.boot:spring-boot-maven-plugin:2.2.7.RELEASE:repackage' with basic configurator -->
[DEBUG] (f) attach = true
[DEBUG] (f) excludeDevtools = true
[DEBUG] (f) excludes = []
[DEBUG] (f) executable = false
[DEBUG] (f) finalName = config-consumer-0.0.1-SNAPSHOT
[DEBUG] (f) includeSystemScope = false
[DEBUG] (f) includes = []
[DEBUG] (f) outputDirectory = /target
[DEBUG] (f) project = MavenProject: com.my.config:config-consumer:0.0.1-SNAPSHOT @ /pom.xml
[DEBUG] (f) skip = false
[DEBUG] -- end configuration --
[INFO] Replaci
ng main arti
fact with repackaged archive
[INFO] -------------------------------------------------------
-----------------
[INFO] BUILD SUCCESS
[INFO] --------------------------
----------------------------------------------
[INFO] Total time: 42.126 s
[INFO] Finished at: 2020-06-02T10:38:05Z
[INFO
] ------------------------------------------------------------------------
Removing intermediate container 1ad5140601c5
---> f68f9fc066f1
Step 5/8 : FROM java:8-jdk-alpine
---> 3fd9dd82815c
Step 6/8 : WORKDIR ./
---> Using cache
---> ef8bf11c31c1
Step 7/8 : EXPOSE 8080
---> Using cache
---> cc296c743b8b
Step 8/8 : ENTRYPOINT ["java", "-jar", "config-consumer-0.0.1-SNAPSHOT.jar"]
---> Using cache
---> 726792fb0fd9
Successfully built 726792fb0fd9
Successfully tagged nitishk58/microservicedummy:latest
Pushing index.docker.io/nitishk58/microservicedummy:latest...
Done!
Build finished
运行容器的错误报告。
sudo docker run -p 3333:8080 nitishk58/microservicedummy
Unable to find image 'nitishk58/microservicedummy:latest' locally
latest: Pulling from nitishk58/microservicedummy
709515475419: Pull complete
38a1c0aaa6fd: Pull complete
5b58c996e33e: Pull complete
Digest: sha256:7cf1809d2ea43c16a103985db626435715e589b898808fb87c565eaa096e52cd
Status: Downloaded newer image for nitishk58/microservicedummy:latest
Error: Unable to access jarfile config-consumer-0.0.1-SNAPSHOT.jar
容器的详细信息如下...
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
38b0a07f9677 nitishk58/microservicedummy "java -jar config-co…" 15 minutes ago Exited (1) 15 minutes ago mystifying_burnell
你的Dockerfile是一个 分期建设 有两个阶段。 当你到达第二个 FROM
行,Docker本质上是重新开始;您的最终映像中没有任何东西会是不属于 COPY
在最后的时间内或以其他方式建造的 FROM
行。
你需要 COPY
第一阶段的jar文件。
COPY --from=MAVEN_BUILD /target/config-consumer-0.0.1-SNAPSHOT.jar .
我会把这个放在 WORKDIR
行。
你应该可以通过运行以下命令来验证同样的事情
docker build -t nitishk58/microservicedummy .
docker run nitishk58/microservicedummy
离线;我希望你会得到同样的结果。
我也可能会把最终的图片改为基于JRE的图片(FROM java:8-jre-alpine
),不包含完整的JDK;这将导致图像明显变小。