在一次使用maven
properties
的过程中遇到属性覆盖的坑。依赖的版本被不小心定义的
properties
修改了。
问题描述
当时情况是这样的,引入公司定义的es starter
,这个starter的部分依赖如下(主要关注版本号是:7.5.0):
<dependency>
<groupId>org.elasticsearch</groupId>
<artifactId>elasticsearch</artifactId>
<version>7.5.0</version>
</dependency>
但是在我的项目引入这个starter 依赖之后,elasticsearch
的版本却是
原因查找
原来是我的项目的pom.xml
中定义了一个属性
<elasticsearch.version>7.5.1</elasticsearch.version>
然后可以通过这个属性来控制elasticsearch
的版本,哪怕我并没有直接使用这个属性。
如果删除了这个属性,就使用默认的版本,也就是5.6.10
一路点开parent pom.xml
最终在spring-boot-dependencies
中找到了这个属性的定义
总结
1.在maven中可以定义属性来覆盖父pom
中定义的属性,这种小范围内定义的属性或者配置(越接近使用者)可以覆盖父节点或者全局属性的思想
在很多软件中有体现,比如disconf
可以本地属性覆盖远程定义的属性,dubbo
的method
级别的配置,可以覆盖service
和 reference
级别的配置等等。