依賴傳遞
當前項目引入了一個依賴,該依賴的依賴也會被引入項目。maven會解析直接依賴的POM,將那些必要的間接依賴,以傳遞依賴的形式引入到當前項目中,這種現象我們稱爲依賴傳遞。
依賴傳遞可能會引起jar包依賴衝突及循環依賴的問題。
依賴衝突解決
依賴調節原則
-
路徑近者優先原則
按照jar包依賴的最短路徑選擇。當同時依賴於spring-contex和spring-webmvc時,都會傳遞過來 spring-beans,那如果直接把spring-beans的依賴直接寫到pom文件中,那麼項目就不會再使用其他依賴傳遞來的spring-beans,因爲自己直接在pom中定義spring-beans要比其他依賴傳遞過來的路徑要近。
-
第一聲明者優先原則
在pom文件定義依賴,以先聲明的依賴爲準。
比如當A依賴C,B依賴於C,在pom中先定義A則導入的jar包版本即爲A依賴於C的版本,若先定義B則導入的jar包版本爲B依賴於C的版本。
排除依賴
比如在依賴zookeeper的設置中添加排除依賴,排除slf4j的依賴
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-dependencies-zookeeper</artifactId>
<version>2.7.2</version>
<type>pom</type>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
</exclusions>
</dependency>
鎖定版本
有一種方法不用考慮依賴路徑、聲明優先等因素,可以採用直接鎖定版本的方法確定依賴構件的版本,版本鎖定後則不考慮依賴的聲明順序或依賴的路徑,以鎖定的版本的爲準添加到工程中。
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring-boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-support</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-oxm</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jms</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring.version}</version>
</dependency>
</dependencies>
</dependencyManagement>