docker 化 maven 项目时出错。构建 Dockerfile 时出错。怎么能解决呢?
Posted
技术标签:
【中文标题】docker 化 maven 项目时出错。构建 Dockerfile 时出错。怎么能解决呢?【英文标题】:Getting error when dokerized maven project. Error at the time of build the Dockerfile. How can solved it? 【发布时间】:2020-11-13 09:31:06 【问题描述】:我想在 Jenkins 中构建一个 docker 镜像。 我的要求是构建war并使用Dockerfile在tomcat中部署一个spring boot应用程序。
我的 Dockerfile 是
FROM maven:3.5-jdk-8-alpine
WORKDIR /app
COPY pom.xml /app/
RUN cd /app/ && mvn install
FROM tomcat:9
EXPOSE 8087
COPY /target/*.war /usr/local/tomcat/webapps/
CMD ["catalina.sh","run"]
我得到的错误是:
[INFO] Total time: 49:49 min
[INFO] Finished at: 2020-07-23T12:21:16Z
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.springframework.boot:spring-boot-maven-plugin:2.4.0-SNAPSHOT:repackage (repackage) on project restcurd: Execution repackage of goal org.springframework.boot:spring-boot-maven-plugin:2.4.0-SNAPSHOT:repackage failed: Unable to find main class -> [Help 1]
[ERROR]
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR]
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/PluginExecutionException
The command '/bin/sh -c cd /app/ && mvn install' returned a non-zero code: 1
Build step 'Execute shell' marked build as failure
运行Dockerfile的命令:docker build -t boot .
我找不到错误的原因。
-
我该如何解决这个问题?
有人告诉我我的 pom.xml 中有错误 有我的 pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.0-SNAPSHOT</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.example</groupId>
<artifactId>restcurd</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>restcurd</name>
<packaging>war</packaging>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
<spring-cloud.version>2020.0.0-SNAPSHOT</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.postgresql</groupId>
<artifactId>postgresql</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>$spring-cloud.version</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<!-- Dockerfile Maven -->
<plugin>
<groupId>com.spotify</groupId>
<artifactId>dockerfile-maven-plugin</artifactId>
<version>1.4.10</version>
<executions>
<execution>
<id>default</id>
<phase>package</phase>
<goals>
<goal>build</goal>
<!-- <goal>push</goal> -->
</goals>
</execution>
</executions>
<configuration>
<repository>pomkiticat/$project.name</repository>
<tag>$project.version</tag>
<skipDockerInfo>true</skipDockerInfo>
</configuration>
</plugin>
<!--docker-->
</plugins>
</build>
<repositories>
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/milestone</url>
</repository>
<repository>
<id>spring-snapshots</id>
<name>Spring Snapshots</name>
<url>https://repo.spring.io/snapshot</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/milestone</url>
</pluginRepository>
<pluginRepository>
<id>spring-snapshots</id>
<name>Spring Snapshots</name>
<url>https://repo.spring.io/snapshot</url>
<snapshots>
<enabled>true</enabled>
</snapshots>
</pluginRepository>
</pluginRepositories>
</project>
我找不到问题。 2. pom.xml 有什么问题? 提前致谢。
【问题讨论】:
你的 pom.xml 可能有问题。我敢打赌,它与 docker 无关。该构建是否可以在您的本地计算机上运行? 是的,它是在我的本地机器上构建的,但是 docker build @Neo Anderson 存在问题。你能告诉我在 pom.xml 中有什么样的问题吗?提前致谢。 【参考方案1】:问题不是 docker 而是你的 pom.尝试使用 shell 以交互模式运行您的 docker 容器,并检查您的 maven 错误并修复它:
FROM maven:3.5-jdk-8-alpine
WORKDIR /app
COPY pom.xml /app/
然后尝试进入你的容器:
docker build -t boot .
docker run -ti boot sh
# # Type in whatever shell command like your maven command and debug it
# mvn install
编辑:
我给出的解释是尝试验证您的 Dockerfile 并在它不起作用时进行理解。您的 Dockerfile 包含用于构建应用程序的“mvn install”命令。但是,正如您在运行此命令时所解释的那样,该命令会失败。
严格来说,您需要 4 个步骤:
第 1 步:确保您的 mvn install build 在本地正常工作,无需涉及任何 docker。看来您错过了主要课程。您是否在没有 docker 的情况下在本地重现此错误?是 => 通过添加该 Main 类来修复它。否 => 进入下一步。
第 2 步:使用 docker 创建一个容器,用于构建您的应用并使其运行。如果它不起作用但您的本地构建工作,那么您的容器有一个与本地不同的执行上下文的问题。我在回复中提出的解决方案是仔细检查。您需要在容器内运行命令。显然你没有用你得到的新错误来做到这一点。我强烈建议您在尝试朝这个方向走得更远之前接受有关使用 docker 的培训,因为您似乎有点迷失了方向。 (无意冒犯,有时我们只需要多训练)。
第 3 步:理想情况下,您的容器仅构建、产生战争,而另一个容器用于运行战争。您不需要源代码 + 最终容器中的所有中间生成文件。
第 4 步:测试您的最终容器。
【讨论】:
我使用的是 Windows 10。 @pampa,我不明白你想说什么?这有什么改变? 实际上我的要求是创建war文件并使用单个Dockerfile将其部署到tomcat。我不想在构建 Dockerfile 后运行 maven 命令。有可能吗? 我已经按照你的步骤了。但是 mvn install 没有运行。它说'mvn' is not recognized as an internal or external command, operable program or batch file.
@nicolasbousquet
@pampa,我会很惊讶 mvn 不是 maven:3.5-jdk-8-alpine 图像的一部分,因为这是该图像和官方图像的主要目标。您确定您确实在正确的上下文中运行了该命令吗?以上是关于docker 化 maven 项目时出错。构建 Dockerfile 时出错。怎么能解决呢?的主要内容,如果未能解决你的问题,请参考以下文章
gitlab+jenkins+maven+docker持续集成——参数化构建过程之多环境tag构建
在 Docker 上构建 vue/quasar 应用程序时出错
docker maven 出错:Failed to execute goal com.spotify:docker-maven-plugin:...: Request error: POST http
Maven 组装 WAR 时出错:使用纯基于 Java 的配置构建 SpringMVC 项目且没有 xml 时需要 webxml 属性
研发环境容器化实施过程(docker + docker-compose + jenkins)
maven 构建项目时出错 “Dynamic Web Module 3.1 requires Java 1.7 or newer” in Eclipse