首先说一下背景,是一个单体的项目,我将它重构为分层的项目,将对外需要的参数和接口单独抽成一层api,打包对外提供出去。父pom用来管理依赖jar包和版本,子pom打包成jar。问题就在这里出现:
1,父依赖打包类型必须是pom
首先第一个问题,maven reload失败,看报错说是父pom必须是Pom类型,而我错误的将之设置为jar。
这里解释一下,父pom既然是用来管理jar包,那么其类型必须为pom类型[1],只有Pom类型的packaging的pom文件才能提供依赖管理的功能。
2,忘记添加dependencymanagement标签
父pom的打包类型改好以后,随之而来的是另一个问题,我在reload的时候发现报错,说api依赖自身。我感觉很奇怪,看api的pom里没有任何依赖,哪里来的依赖呢。想到这里,又发现了另一件奇怪的事,我在api里没有添加任何依赖,api里的lombok,rest注解等为什么没有报错呢?
想到这里,我赶紧去父pom里看了下,果然,是父pom直接用<dependencies>
标签,外层没有<dependendymanagement>
这个标签。
需要说明的是,打了<dependencies>
标签的例如名为a的project或者module,凡是依赖或是继承了它的例如名为b的包,在b项目中无需声明即可将a中的依赖全部集成;而<dependendymanagement>
则需要声明<groupId>
和<artifactId>
才能继承(无需<version>
标签,版本由<dependendymanagement>
管理)。
由于我忘记加了<dependendymanagement>
,本应在<dependendymanagement>
中管理的<api>
,被api自身集成了,因此出现了引用自身的错误。添加<dependendymanagement>
后,报错消失,同时api里的依赖消失,此后添加api需要的依赖重新reload即可。
最后,需要说的是,在多层module的project中,父pom起到的作用仅仅是提供依赖和版本的管理,包括自身的子module和第三方依赖,因此打包类型为pom,需要<dependendymanagement>标签
;
而子module,则是具体工作的模块,因此类型需要为jar或者war(我一般用jar),不需要<dependendymanagement>标签,而需要用<dependencies>标签将父pom中的依赖显示的有选择的继承
。
有的时候工作忙的昏了头,早上清醒的时候一看,问题非常明显,但是有时候就看不出来QAQ
参考文章
[1],Maven的三种项目打包方式——pom,jar,war的区别