关于maven项目多模块的打包问题的血泪经历(必看)

关于maven项目多模块的打包问题的血泪经历(必看)

最近公司使用springboot开发项目,使用的构建工具是maven,项目分了很多模块,并且模块之间还存在一定的依赖,比如说一个项目common是提供各项目通用的工具类,公共的类等

请添加图片描述

例子:项目root,有module common,front,mall等其中front 和mall都依赖于common,将来需要上线部署的也是front和mall项目,所以两个项目是要进行打包,也就是这个打包操作,让我浪费了好多时间,这里都是我亲身经历的血泪史。。

当使用Maven对front项目直接进行package时,提示依赖于common的jar包找不到。因为直接对front打包,common并没有被打包,依赖关系无法保持。这时你要做的就是,首先对项目common进行install,如图
请添加图片描述

注意!注意!这里有一个巨坑,我已经义无反顾的跳进去一次了,大家一定不要再往里面跳了:Common打包出来的应该是不可执行的jar包,所以不要在Common的pom中定义spring-boot-maven-plugin插件,因为这个SpringBoot插件会在Maven的package后进行二次打包,目的为了生成可执行jar包,如果C中定义了这个插件,会报错提示没有找到main函数。这时你就可以去打包front项目了,当然打包的时候可能还是不行,这里还有一个小坑,如果还是不能进行打包的话,那么就install一下root项目,也就是总目录下的pom文件对应的install操作,这样再打包front项目基本上就没有问题了,老铁,都是经验呀,希望对你们有帮助

一般对使用spring-boot-maven-plugin插件打出的可执行jar不建议作为jar给其他服务引用,因为可能出现访问可执行jar中的一些配置文件找不到的问题。如果想让构建出来的原始jar(没有引入插件相关的包并且没有更改MANIFEST.MF)不被重新打包(重新打包会引入spring-boot-maven-plugin定制的配置和jar包),可以对spring-boot-maven-plugin插件配置classifier属性,自定义一个可运行jar名称,这样该插件就不会对原始的jar重命名操作了。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我理解了你的问题。针对 Maven模块合并打包,可以按照以下步骤进行操作: 1. 创建 Maven模块项目,将需要合并打包模块作为子模块引入到父模块中。 2. 在父模块的 pom.xml 文件中,使用 maven-assembly-plugin 插件配置合并打包的规则。例如: ``` <plugin> <artifactId>maven-assembly-plugin</artifactId> <version>3.3.0</version> <configuration> <finalName>merged-jar</finalName> <appendAssemblyId>false</appendAssemblyId> <descriptors> <descriptor>assembly.xml</descriptor> </descriptors> </configuration> <executions> <execution> <id>make-assembly</id> <phase>package</phase> <goals> <goal>single</goal> </goals> </execution> </executions> </plugin> ``` 其中,finalName 表示打包后的文件名,appendAssemblyId 表示不使用默认的 assemblyId,descriptors 表示使用 assembly.xml 文件定义打包规则。 3. 在父模块中创建 assembly.xml 文件,定义打包规则。例如: ``` <assembly xmlns="http://maven.apache.org/ASSEMBLY/2.1.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/ASSEMBLY/2.1.0 http://maven.apache.org/xsd/assembly-2.1.0.xsd"> <id>jar-with-dependencies</id> <formats> <format>jar</format> </formats> <includeBaseDirectory>false</includeBaseDirectory> <dependencySets> <dependencySet> <outputDirectory>/</outputDirectory> <useProjectArtifact>false</useProjectArtifact> <useTransitiveDependencies>true</useTransitiveDependencies> <scope>runtime</scope> </dependencySet> </dependencySets> </assembly> ``` 其中,id 表示打包规则的名称,formats 表示打包的格式,dependencySets 表示依赖的配置。这里的配置表示将所有运行依赖打包到根目录下。 4. 执行 Maven 打包命令,例如: ``` mvn clean package ``` 5. 在父模块的 target 目录下,会生成一个 merged-jar.jar 的文件,含了所有的子模块依赖。 至此,你就可以成功地实现了 Maven模块合并打包的操作。希望这个回答能够对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值