使用 Maven 构建多模块项目及问题处理

问题处理

循环依赖

构建时报错:

[exec] [ERROR] The projects in the reactor contain a cyclic reference: Edge between 'Vertex{label='com.xxx.xxx:aaa:0.0.49'}' and 'Vertex{label='com.xxx.xxx:bbb:0.0.49'}' introduces to cycle in the graph com.xxx.xxx:bbb:0.0.49 --> com.com.xxx.xxx:aaa:0.0.49 --> com.xxx.xxx:bbb:0.0.49 -> [Help 1]

解决方案:

夫工程的依赖 dependencies 加上 dependencyManagement 标签。

<dependencyManagement>
    <dependencies>
    </dependencies>
</dependencyManagement>

Maven 通过 dependencyManagement 元素来管理 jar 包的版本,让⼦项⽬中引⽤⼀个依赖,⽽不⽤显⽰的列出版本号。Maven 会沿着⽗⼦层次向上⾛,直到找到⼀个拥有 dependencyManagement 元素的项⽬,然后它就会使⽤在
这个 dependencyManagement 元素中指定的版本号。
这样做的好处:统⼀管理项⽬的版本号,确保应⽤的各个项⽬的依赖和版本⼀致,才能保证测试的和发布的是相同的成果,因此,在顶层
pom 中定义共同的依赖关系。同时可以避免在每个使⽤的⼦项⽬中都声明⼀个版本号,这样想升级或者切换到另⼀个版本时,只需要在⽗类
容器⾥更新,不需要任何⼀个⼦项⽬的修改;如果某个⼦项⽬需要另外⼀个版本号时,只需要在 dependencies 中声明⼀个版本号即可。⼦
类就会使⽤⼦类声明的版本号,不继承于⽗类版本号。

在最顶级的项⽬中才需要配置 标签,其⼦项⽬在标签中继承该顶级项⽬的 pom.xml ⽂件即可。

继承后⼦项⽬中的 jar 包的版本就跟顶级项⽬ pom.xml ⽂件中规定的⼀致。

dependencies 和 dependencyManagement 的区别在于:

  • 前者,即使在⼦项⽬中不写该依赖项,那么⼦项⽬仍然会从⽗项⽬中继承该依赖项。
  • 后者,如果在⼦项⽬中不写该依赖项,那么⼦项⽬中是不会从⽗项⽬继承该依赖项的;只有在⼦项⽬中写了该依赖项,才会从⽗项⽬中继承该项,并且 version 和 scope 都读取⾃ ⽗ pom。