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