自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

如何避免Java項(xiàng)目中的循環(huán)依賴問(wèn)題

開(kāi)發(fā) 后端
當(dāng)我們開(kāi)發(fā)一個(gè)Java項(xiàng)目時(shí),我們要做的第一件事就是添加我們需要使用的依賴項(xiàng),庫(kù)或框架。為此,我們使用依賴管理工具(例如Maven或Gradle),來(lái)管理我們的項(xiàng)目依賴。

[[384504]]

 前言

當(dāng)我們開(kāi)發(fā)一個(gè)Java項(xiàng)目時(shí),我們要做的第一件事就是添加我們需要使用的依賴項(xiàng),庫(kù)或框架。為此,我們使用依賴管理工具(例如Maven或Gradle),來(lái)管理我們的項(xiàng)目依賴。

我們?yōu)轫?xiàng)目添加的每個(gè)依賴項(xiàng)都包含其他依賴項(xiàng)。我們都知道依賴傳遞這個(gè)概念。在許多情況下,項(xiàng)目的依賴傳遞不會(huì)有任何的問(wèn)題,因?yàn)橐蕾嚬芾砉ぞ?Maven或Gradle)很好地解決了不同庫(kù)之間的版本沖突。但是,在其他情況下,當(dāng)使用我們的API /庫(kù)時(shí)或者不同的庫(kù)依賴的同一個(gè)庫(kù)不同版本,這些沖突會(huì)產(chǎn)生一些錯(cuò)誤。

舉個(gè)例子:


圖中我們的API 庫(kù)導(dǎo)入了一些庫(kù),但這些庫(kù)同時(shí)依賴了庫(kù)X的不同版本,這樣就好出現(xiàn)依賴沖突。

如何解決這個(gè)問(wèn)題

在沒(méi)有Maven & Gradle 庫(kù)管理工具之前,我們開(kāi)發(fā)一個(gè)Java項(xiàng)目需要耗費(fèi)大量的時(shí)間去解決我們項(xiàng)目的依賴沖突,Maven & Gradle工具的引入極大的解決了我們依賴的問(wèn)題,但很多時(shí)候我們還是會(huì)看到諸如:ClassNotFoundException,MethodNotSupportedException,NoClassDefNotFound這個(gè)時(shí)候很多情況下依賴開(kāi)發(fā)人員的經(jīng)驗(yàn)手動(dòng)去解決,同時(shí)我們也可以依賴一些開(kāi)發(fā)工具去幫助我們排查問(wèn)題,如:

Eclipse / IntelliJ 開(kāi)發(fā)工具中的Dependency Analyzer

他可以展示所有的依賴項(xiàng)并協(xié)助開(kāi)發(fā)人員定位到有沖突的庫(kù)。


當(dāng)您檢測(cè)哪些庫(kù)包含導(dǎo)致問(wèn)題的依賴項(xiàng)時(shí),需要從我們的依賴項(xiàng)管理文件(pom.xml或build.gradle)中排除所有包含不同版本依賴項(xiàng)的庫(kù)。

maven-enforcer-plugin插件

Maven提供了Maven-Enforcer-Plugin插件,用來(lái)校驗(yàn)約定遵守情況(或者說(shuō)校驗(yàn)開(kāi)發(fā)環(huán)境)。比如JDK的版本,Maven的版本,開(kāi)發(fā)環(huán)境(Linux,Windows等),依賴jar包的版本等等

插件使用只需要在pom中引入即可:

  1. <plugin> 
  2.     <groupId>org.apache.maven.plugins</groupId> 
  3.     <artifactId>maven-enforcer-plugin</artifactId> 
  4.     <version>1.3.1</version> 
  5.     <executions> 
  6.         <execution> 
  7.             <id>enforce</id> 
  8.             <configuration> 
  9.                 <rules> 
  10.                     <DependencyConvergence/> 
  11.                 </rules> 
  12.             </configuration> 
  13.             <goals> 
  14.                 <goal>enforce</goal> 
  15.             </goals> 
  16.         </execution> 
  17.     </executions> 
  18. </plugin> 

在進(jìn)行mvn clean package的時(shí)候,會(huì)在console中打印出來(lái)沖突的jar版本和其父pom,如下:

  1. [INFO] --- maven-enforcer-plugin:1.3.1:enforce (enforce) @ uaf-uafei-provider --- 
  2. [WARNING]  
  3. Dependency convergence error for com.google.guava:guava:16.0 paths to dependency are: 
  4. +-com.uaf.uafei:uaf-uafei-provider:0.2.09-SNAPSHOT 
  5.   +-com.uaf:microservice-sleuth:0.2.09-SNAPSHOT 
  6.     +-org.springframework.cloud:spring-cloud-starter-openfeign:2.1.5.RELEASE 
  7.       +-io.github.openfeign:feign-hystrix:10.4.0 
  8.         +-com.netflix.archaius:archaius-core:0.7.6 
  9.           +-com.google.guava:guava:16.0 
  10. and 
  11. +-com.uaf.uafei:uaf-uafei-provider:0.2.09-SNAPSHOT 
  12.   +-com.uaf:microservice-apollo:0.2.09-SNAPSHOT 
  13.     +-com.google.inject:guice:4.1.0 
  14.       +-com.google.guava:guava:19.0 
  15.  
  16. [WARNING] Rule 0: org.apache.maven.plugins.enforcer.DependencyConvergence failed with message: 
  17. Failed while enforcing releasability the error(s) are [ 
  18. Dependency convergence error for com.google.guava:guava:16.0 paths to dependency are: 
  19. +-com.uaf.uafei:uaf-uafei-provider:0.2.09-SNAPSHOT 
  20.   +-com.uaf:microservice-sleuth:0.2.09-SNAPSHOT 
  21.     +-org.springframework.cloud:spring-cloud-starter-openfeign:2.1.5.RELEASE 
  22.       +-io.github.openfeign:feign-hystrix:10.4.0 
  23.         +-com.netflix.archaius:archaius-core:0.7.6 
  24.           +-com.google.guava:guava:16.0 
  25. and 
  26. +-com.uaf.uafei:uaf-uafei-provider:0.2.09-SNAPSHOT 
  27.   +-com.uaf:microservice-apollo:0.2.09-SNAPSHOT 
  28.     +-com.google.inject:guice:4.1.0 
  29.       +-com.google.guava:guava:19.0 

結(jié)論

依賴沖突是開(kāi)發(fā)過(guò)程中比較耗時(shí)的一個(gè)問(wèn)題,通過(guò)諸如以上的一些功能協(xié)助我們盡快定位到問(wèn)題,但最好的解決方式還是要遵循開(kāi)發(fā)中的規(guī)范,約定優(yōu)于配置。

 

責(zé)任編輯:姜華 來(lái)源: 編碼是個(gè)技術(shù)活
相關(guān)推薦

2024-02-01 09:58:40

Java內(nèi)存泄漏

2024-01-30 10:12:00

Java內(nèi)存泄漏

2022-12-04 23:54:39

2022-11-23 15:44:49

2019-11-26 14:30:20

Spring循環(huán)依賴Java

2023-04-21 10:08:00

版本工具依賴關(guān)系

2023-05-04 08:06:27

Spring循環(huán)依賴

2020-11-04 10:11:22

區(qū)塊鏈塊鏈技術(shù)

2019-07-01 10:43:15

區(qū)塊鏈技術(shù)數(shù)據(jù)

2018-03-12 13:25:51

2023-11-28 08:00:00

SpringJava

2024-09-12 15:36:57

2022-12-29 07:37:19

Java項(xiàng)目慢業(yè)務(wù)

2009-06-22 15:01:00

java項(xiàng)目常見(jiàn)錯(cuò)誤

2019-03-25 10:30:19

開(kāi)發(fā)技能代碼

2023-12-21 08:51:37

防抖節(jié)流Vue.js

2020-12-29 08:34:08

spring循環(huán)依賴開(kāi)發(fā)

2020-06-03 10:09:03

微服務(wù)項(xiàng)目版本號(hào)

2011-07-08 08:37:05

軟件開(kāi)發(fā)

2020-10-27 14:15:42

SpringBoot
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)