使用API模块的Maven多项目构建似乎不包括构建图像中的项目级依赖关系



你好,我有一个springboot多项目Maven构建,该构建构建了多个图像。该结构类似于:

- project-parent
   - common
   - project-b-parent
      - project-b-api
      - project-b-gateway
      - project-b-launcher
   - project-c-parent
      - project-c-api
      - project-c-gateway
      - project-c-launcher

*启动器模块是我的Springboot Uber罐子和网关是Spring MVC控制器和支持类,而API是启动器模块中的项目级依赖项。例如,Project-C对Project B-API

有依赖性

我的项目 - 父母POM具有:

   ...
   <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.2.RELEASE</version>
   </parent>
   <version>0.0.1-SNAPSHOT</version>
   <groupId>my.group</groupId>
   <artifactId>project-parent</artifactId>
   <packaging>pom</packaging>
   ...
   <modules>
        <module>project-b-parent</module>
        <module>project-c-parent</module>
    </modules>
    ...
    <properties>
        <jib.skip>true</jib.skip>
    </properties>
    ...
    <build>
        <pluginManagement>
            <plugins>
                <plugin>
                    <groupId>com.google.cloud.tools</groupId>
                        <artifactId>jib-maven-plugin</artifactId>
                        <version>1.0.0</version>
                        <configuration>
                            <from>
                                <image>my.base.image:latest</image>
                            </from>
                            <to>
                                <image>my.image.registry/${project-name}</image>
                                <tags>
                                    <tag>${project.version}</tag>
                                    <tag>latest</tag>
                                </tags>
                            </to>
                            <allowInsecureRegistries>true</allowInsecureRegistries>
                    </configuration>
                </plugin>
            </plugins>
        </pluginManagement>
    </build>

注意,我已将<jib.skip>true</jib.skip>添加到我的父pom中。我在发射器中有<jib.skip>false</jib.skip>,这创建了仅从 *启动器模块创建图像的预期行为。

所有模块版本均版本为0.0.1-snapshot。

当我使用潜水检查我的图像时,我没有快照依赖性层,并且我的项目级依赖项似乎不在图像中。

当我运行应用程序时,他们似乎会启动Springboot并在端口上聆听,而控制器的终点未加载。尝试从项目级依赖项加载类时,另一个项目会引发NoclassDeffoundError异常。

我已经尝试将所有内容视为0.0.1,没有快照,而我的项目级依赖项不包括在我的依赖层中。

我还尝试过运行mvn -X -DjibSerialize=true clean compile jib:build > logs.txt和我的类级依赖项

...
[INFO] --- jib-maven-plugin:1.0.0:build (default-cli) @ project-b-launcher ---
[DEBUG] Configuring mojo com.google.cloud.tools:jib-maven-plugin:1.0.0:build from plugin realm ClassRealm[plugin>com.google.cloud.tools:jib-maven-plugin:1.0.0, parent: sun.misc.Launcher$AppClassLoader@5c647e05]
[DEBUG] Configuring mojo 'com.google.cloud.tools:jib-maven-plugin:1.0.0:build' with basic configurator -->
[DEBUG]   (f) allowInsecureRegistries = true
[DEBUG]   (f) mainClass = project-b.stuff.ApplicationKt
[DEBUG]   (f) container = com.google.cloud.tools.jib.maven.JibPluginConfiguration$ContainerParameters@77662d13
[DEBUG]   (f) image = my.registry/distroless-java:latest
[DEBUG]   (f) from = com.google.cloud.tools.jib.maven.JibPluginConfiguration$FromConfiguration@6a0328d7
[DEBUG]   (f) project = MavenProject: my.company:project-a-launcher:0.0.1 @ C:my-programsproject-parentproject-b-parentproject-b-launcherpom.xml
[DEBUG]   (f) session = org.apache.maven.execution.MavenSession@51ec2df1
[DEBUG]   (f) skip = false
[DEBUG]   (f) image = my-new-image
[DEBUG]   (f) tags = [0.0.1, latest]
[DEBUG]   (f) to = com.google.cloud.tools.jib.maven.JibPluginConfiguration$ToConfiguration@6370bf52
[DEBUG] -- end configuration --
[INFO] 
[INFO] Containerizing application to my.registryproject-parentproject-b-parentproject-b-launcher, my.registryproject-parentproject-b-parentproject-b-launchercustomer-launcherproject-b-launcher:0.0.1-SNAPSHOT, my.registryproject-parentproject-b-parentproject-b-launchercustomer-launcherproject-b-launcher...
[DEBUG] Containerizing application with the following files:
[DEBUG]     Dependencies:
[DEBUG]         C:my-programsproject-parentproject-c-parentproject-c-gatewaytargetclasses
[DEBUG]         C:my-programsproject-parentproject-c-parentproject-c-apitargetclasses
[DEBUG]         C:Usersme.m2repositoryorgspringframeworkspring-web5.1.4.RELEASEspring-web-5.1.4.RELEASE.jar
...

请注意,我在此调试日志输出中重命名了许多敏感目录等。我不确定第二和第三底线(项目级依赖项)是否应该指向Target class - 他们应该参考.jars吗?我想他们不能如果我只做MVN编译吉布:build

我希望我已经将其发布到正确的位置。

事实证明,OP的项目设置存在问题。(https://github.com/googlecontainertools/jib/issues/1539中的详细信息。)基本上,spring-boot-maven-pluginjib-maven-plugin均在根pom.xml上应用。这导致

  • spring-boot-maven-plugin试图为每个子模块创建一个可运行的jar,其中一些是没有主类的库。
  • jib-maven-plugin试图为每个子模块以及顶部项目构建图像。

最新更新