转载:https://www.cnblogs.com/huahua035/p/7680607.html
在maven多模块项目中,为了保持模块间依赖的统一,常规做法是在parent model中,使用dependencyManagement预定义所有模块需要用到的dependency(依赖)
<dependencyManagement>
<dependencies>
<!-- Feign是一种声明式、模板化的HTTP客户端:以HTTP接口的形式暴露自身服务 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-feign</artifactId>
<version>${spring-cloud-starter-feign.version}</version>
</dependency>
<!-- 支持面向方面的编程即AOP,包括spring-aop和AspectJ -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
<version>${spring.boot.version}</version>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjrt</artifactId>
<version>${aspectjrt.version}</version>
</dependency>
</dependencies>
</dependencyManagement>
然后,子model根据实际需要引入parent中预定义的依赖,
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
</dependencies>
好处:
1、依赖统一管理(parent中定义,需要变动dependency版本,只要修改一处即可);
2、代码简洁(子model只需要指定groupId、artifactId即可)
3、dependencyManagement只会影响现有依赖的配置,但不会引入依赖,即子model不会继承parent中dependencyManagement所有预定义的depandency,只引入需要的依赖即可,简单说就是“按需引入依赖”或者“按需继承”;因此,在parent中严禁直接使用depandencys预定义依赖,坏处是子model会自动继承depandencys中所有预定义依赖;
但是,问题也出现了:
单继承:maven的继承跟java一样,单继承,也就是说子model中只能出现一个parent标签;
parent模块中,dependencyManagement中预定义太多的依赖,造成pom文件过长,而且很乱;
如何让这些依赖可以分类并清晰的管理?
问题解决:import scope依赖
如何使用:
1、maven2.9以上版本
2、将dependency分类,每一类建立单独的pom文件
3、在需要使用到这些依赖的子model中,使用dependencyManagement管理依赖,并import scope依赖
3、注意:scope=import只能用在dependencyManagement里面,且仅用于type=pom的dependency
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<!-- 重要:版本号要和父模块中预定义的spring boot版本号保持一致 -->
<version>${spring.boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
个人总结
看了几篇文章,看了这个之后总算知道了这个是什么意思。
1.一般多模块管理依赖都是在父pom.xml声明dependencyManagement,然后子模块显示依赖(无需版本)
dependencyManagement: 专门为了管理模块依赖,不会被直接传递到子模块,需要显示依赖。
父pom.xml不应该定义dependencies,除非是所有模块都需要的,因为这个会直接传递给子模块
2.但是如果我们还需要引用其他系统的一些模块,写很多个dependency显然太low,如果能直接引用这个系统的父pom.xml就好了
但是maven是单继承,因此子模块不能再继承其他系统的parent pom.xml了.
于是就有了scope:import
》只能在dependencyManagement
》type只能是pom.xml(即父pom.xml)
》是声明在parent pom.xml的dependencyManagement,提供给子模块引用的
作用就相当于把其他系统的父pom.xml的子模块全部引入进来了,
并且子模块在用的时候可以只需要依赖该系统的一部分模块
(例如import spring-parent.pom, 子模块可以只依赖spring-web)