如何避免Java项目中的循环依赖问题

2025-05-29 0 96

如何避免Java项目中的循环依赖问题

前言

当我们开发一个Java项目时,我们要做的第一件事就是添加我们需要使用的依赖项,库或框架。为此,我们使用依赖管理工具(例如Maven或Gradle),来管理我们的项目依赖

我们为项目添加的每个依赖项都包含其他依赖项。我们都知道依赖传递这个概念。在许多情况下,项目的依赖传递不会有任何的问题,因为依赖管理工具(Maven或Gradle)很好地解决了不同库之间的版本冲突。但是,在其他情况下,当使用我们的API /库时或者不同的库依赖的同一个库不同版本,这些冲突会产生一些错误。

举个例子:

如何避免Java项目中的循环依赖问题

图中我们的API 库导入了一些库,但这些库同时依赖了库X的不同版本,这样就好出现依赖冲突。

如何解决这个问题

在没有Maven & Gradle 库管理工具之前,我们开发一个Java项目需要耗费大量的时间去解决我们项目的依赖冲突,Maven & Gradle工具的引入极大的解决了我们依赖的问题,但很多时候我们还是会看到诸如:ClassNotFoundException,MethodNotSupportedException,NoClassDefNotFound这个时候很多情况下依赖开发人员的经验手动去解决,同时我们也可以依赖一些开发工具去帮助我们排查问题,如:

Eclipse / IntelliJ 开发工具中的Dependency Analyzer

他可以展示所有的依赖项并协助开发人员定位到有冲突的库。

如何避免Java项目中的循环依赖问题

当您检测哪些库包含导致问题的依赖项时,需要从我们的依赖项管理文件(pom.xml或build.gradle)中排除所有包含不同版本依赖项的库。

maven-enforcer-plugin插件

Maven提供了Maven-Enforcer-Plugin插件,用来校验约定遵守情况(或者说校验开发环境)。比如JDK的版本,Maven的版本,开发环境(Linux,Windows等),依赖jar包的版本等等

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

<plugin>

<groupId>org.apache.maven.plugins</groupId>

<artifactId>maven-enforcer-plugin</artifactId>

<version>1.3.1</version>

<executions>

<execution>

<id>enforce</id>

<configuration>

<rules>

<DependencyConvergence/>

</rules>

</configuration>

<goals>

<goal>enforce</goal>

</goals>

</execution>

</executions>

</plugin>

在进行mvn clean package的时候,会在console中打印出来冲突的jar版本和其父pom,如下:

[INFO]—maven-enforcer-plugin:1.3.1:enforce(enforce)@uaf-uafei-provider—

[WARNING]

Dependencyconvergenceerrorforcom.google.guava:guava:16.0pathstodependencyare:

+-com.uaf.uafei:uaf-uafei-provider:0.2.09-SNAPSHOT

+-com.uaf:microservice-sleuth:0.2.09-SNAPSHOT

+-org.springframework.cloud:spring-cloud-starter-openfeign:2.1.5.RELEASE

+-io.github.openfeign:feign-hystrix:10.4.0

+-com.netflix.archaius:archaius-core:0.7.6

+-com.google.guava:guava:16.0

and

+-com.uaf.uafei:uaf-uafei-provider:0.2.09-SNAPSHOT

+-com.uaf:microservice-apollo:0.2.09-SNAPSHOT

+-com.google.inject:guice:4.1.0

+-com.google.guava:guava:19.0

[WARNING]Rule0:org.apache.maven.plugins.enforcer.DependencyConvergencefailedwithmessage:

Failedwhileenforcingreleasabilitytheerror(s)are[

Dependencyconvergenceerrorforcom.google.guava:guava:16.0pathstodependencyare:

+-com.uaf.uafei:uaf-uafei-provider:0.2.09-SNAPSHOT

+-com.uaf:microservice-sleuth:0.2.09-SNAPSHOT

+-org.springframework.cloud:spring-cloud-starter-openfeign:2.1.5.RELEASE

+-io.github.openfeign:feign-hystrix:10.4.0

+-com.netflix.archaius:archaius-core:0.7.6

+-com.google.guava:guava:16.0

and

+-com.uaf.uafei:uaf-uafei-provider:0.2.09-SNAPSHOT

+-com.uaf:microservice-apollo:0.2.09-SNAPSHOT

+-com.google.inject:guice:4.1.0

+-com.google.guava:guava:19.0

]

结论

依赖冲突是开发过程中比较耗时的一个问题,通过诸如以上的一些功能协助我们尽快定位到问题,但最好的解决方式还是要遵循开发中的规范,约定优于配置。

原文地址:https://mp.weixin.qq.com/s/d0TRBo9uG4NTYh_TS88lYQ

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 如何避免Java项目中的循环依赖问题 https://www.kuaiidc.com/113931.html

相关文章

发表评论
暂无评论