背景
- 很多是时候,在使用maven依赖jar包时,会由于某个jar包被重复依赖,且版本不一致,导致项目无法启动,或启动后,使用某个jar包报错
- 如:最常见 log4j-api 依赖包版本不一致,导致启动项目时报红
解决示例:
- 示例
- 比如:当前项目中存在重复依赖mybatis:3.5.9 和 mybatis:3.5.10,如下(图1)所示
- 现在我们想保留mybatis:3.5.10,排除掉mybatis:3.5.9
- 下图就是idea显示的当前项目依赖关系图,从图中我们可以看出,mybatis存在重复依赖,且版本不一致
- 第一步:显示module中所有依赖关系图(多module时,哪个module存在重复依赖,就显示哪个)
- 在idea右侧【toolbar】中,打开【maven】工具窗口
- 选中【需要处理的model】,然后点击【show dependencies】
- 如下(图2)所示
- 第二步:搜索存在冲突的依赖包名
- 在【依赖关系图】窗口中,按【Ctrl + F】进行打开【Diagram Elements】窗口,然后直接搜索存在冲突的依赖包名称
- 比如:当前我的项目中,mybatis存在重复依赖包,所以搜【mybatis】
- 注意:虽然 Diagram Elements 窗口没有搜索框,但是当键入字符时,会自动进入搜索模式
- 如下(图3)所示
- 第三步:抽取选中依赖包的整个依赖关系图
- 搜索到需要的依赖后,鼠标直接点击依赖包,再点击【Root -> Selection】按钮,idea会自动将依赖从Root(根)到当前所选的依赖包的关系图给抽离出来,并展示
- 比如:这里我们想找到【mybatis:3.5.10】这个依赖,如下(图4)所示
- 当我们点击【Root->Selection】后,idea将选中依赖关系图抽取如下(图5)所示
- 如果觉得不方便看,可以选择【Export Diagram】按钮,将关系图导出,操作如下(图6)所示
- 操作导出后,idea会自动在浏览器中打开到处结果,并如下(图7)所示
- 第四步:分析依赖关系
- 从上面(图5)或(图7)中,我们没有看到【mybatis:3.5.10】与哪个包存在重复依赖,所以,我们需要再去检查一下【mybatis:3.5.9】依赖包是否有问题。
- 同理,我们将【mybatis:3.5.9】依赖包关系图抽取出来,如下(图8和图9)所示
- 第五步:找到重复依赖是从哪里被引入进来的(以便后续分析和解决问题)
- 从上面 图8 和 图9 中,我们并不知道【mybatis:3.5.9】是从哪个依赖包中被引入进来的。
- 想要找到【mybatis:3.5.9】是从哪个依赖包中引入进来的,只需要双击【mybatis:3.5.9】依赖包(下图10),idea就会自动打开其父依赖的所在pom文件
- 我们从idea自动打开的pom文件中(下图11),可以确认【mybatis:3.5.9】是在【mybatis-spring-boot-starter-2.2.2.pom】中引入的
- 抽取【mybatis:3.5.9】的父依赖【mybatis-spring-boot-starter:2.2.2】的依赖关系图,结果如下(图12 和 图13)所示
- 第六步:确定取舍依赖包
- 上面找到了【mybatis:3.5.9】和 【mybatis:3.5.10】两个依赖的关系图(为了方便,我将两个依赖图放在下面一起看)。接下来就是要分析这两个依赖,应该要排除掉哪个依赖,保留哪个依赖
- 【mybatis:3.5.10】是项目中的【mybatis-plus-boot-starter:3.5.2】引入的,该jar包是用来进行数据库操作的
- 【mybatis:3.5.9】是项目中【pagehelper-spring-boot-starter:1.4.6】引入的,该jar包是用来进行分页的插件
- 故:从影响面考虑,应该排除【pagehelper-spring-boot-starter:1.4.6】引入的【mybatis:3.5.9】
- Tips:这里,我们可以发现,其实在搜【mybatis:3.5.9】时,就已经给出其依赖关系图,只是少了一个连接线而已(如下左边图中红线)
- 第七步:排除重复依赖
- 根据上面分析的结果,本次示例中,我们需要排除【mybatis:3.5.9】依赖包
- 【mybatis:3.5.9】是被【pagehelper-spring-boot-starter:1.4.6】引入进来的
- 故:在引入【pagehelper-spring-boot-starter:1.4.6】的地方,进行排除操作即可,如下(图15)所示
- 最后:验证排除结果
- 再次打开【show dependencies】,并搜索【mybatis】发现此时只有一个【mybatis:3.5.10】依赖包
- 如下(图16)所示