前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >记一次线上问题排查-maven父子结构依赖所遇到的坑

记一次线上问题排查-maven父子结构依赖所遇到的坑

作者头像
用户4464623
发布2020-09-14 11:50:31
7720
发布2020-09-14 11:50:31
举报

场景:

基于springboot框架所搭建的maven工程,而且都是相互独立的。有个parent父工程,common基础模块、以及其他模块(Module A、Module B)等。

问题:

有个RabbitMQ producer生产者模块需要作为jar包被其他工程引入比如Module A。在对Module A进行打包时,出现问题:Module A中所依赖的producer工程的util程序包不存在。即使能打包成功,用java -jar启动jar包也会报Class Not Found,依赖的producer工程的类找不到。

解决方案:

未解决之前在producer工程的pom.xml中maven插件的配置如下:

<build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                   
                </plugin>
             
            </plugins>
        </build>

解决之后producer工程的pom.xml中maven插件的配置如下:

<build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                    <configuration>
                        <classifier>exec</classifier>
                    </configuration>
                </plugin>
             
            </plugins>
        </build>

第二种解决方案:

注释如下代码就能直接打包可依赖的jar包
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                   
                </plugin>
             
            </plugins>

原因分析:

spring-boot-maven-plugin打包出来的jar是不可依赖的

我们现在整合后的maven项目有一个parent工程,打包类型为pom,下面多个spring-boot工程作为它的module,分别为producer和moduleA,moduleB。假如moduleA依赖于producer。如果你在producer中使用了spring-boot-maven-plugin的默认配置build,或者在parent工程中使用spring-boot-maven-plugin的默认配置build。那么在clean package的时候会发现moduleA找不到base中的类。原因就是默认打包出来的jar是不可依赖的。

解决方案:

官方告诉我们,你如果不想移代码,好吧,我这样来给你解决,给你打两个jar包,一个用来直接执行,一个用来依赖。于是,你需要指定一个属性classifier,这个属性为可执行jar包的名字后缀。比如我设置<classifier>exec</classifier>,原项目名为Vehicle-business。那么会得到两个jar:Vehicle-business.jar和Vehicle-bussiness-exec.jar

官方文档位置:84.5 Use a Spring Boot application as a dependency

总结:回到聚合maven上,如果你在parent工程中使用了spring-boot-maven-plugin作为builder,那么你的依赖module一定要用解决方案二来设置。否则你不在parent工程中用spring-boot-maven-plugin作为builder,而在需要打包的module上使用。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 场景:
  • 问题:
  • 解决方案:
    • 第二种解决方案:
      • 原因分析:
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档