前言:

今天学习和总结了一下maven的相关知识点,发现一些比较基础的东西居然也会忘记,这里对于一些日常工作中可能会遇到的问题进行了一下汇总。

idea怎么创建maven多module的项目

首先了解上面是多module?

一句话概括就是:一个父模块作为版本控制多个子模块,子模块负责接入到父模块当中作为整个项目的过程。

多Module管理项目的几种方式:

  1. 按照单模块拆分为多个子模块,比如将MVC三层架构拆分为 xxx-service,xxx-dao,xxx-model,不过这种方式个人感觉比较二,目前以业务模块拆分比较多,迁移到微服务比如用springcloude或者dubbo 的时候非常好用。
  2. 按照业务模块拆分,这种模式使用的比较多,也比较多见。

创建一个多module项目(idea2019.3.3版本)

创建一个父pom项目:

  1. 打开idea,选择 create new project
  1. 选择maven项目,同时不选任何的预加载设置
  1. 父pom配置如下:
  1. 删除 src 目录

创建子模块,引入到父pom里面

  1. 同样右击项目工程,选择 new module ,然后选择 maven ,这时候会出现父模块以及对应的子模块名称
  1. 此时在父模块里面发现引入了子模块的内容

子父模块的区别:

pom.xml文件内容:

org.zxdtaglibpom1.0.0taglib-core

分为两个部分,一个部分是父pom的声明,包含gourpId,artifactId,打包方式 必须是pom ,因为使用了 聚合模型 ,同时在父pom里面指定版本号,子模块不填写version会默认使用父pom的version号

taglib-core

上面表示当前引入的子模块内容

子pom.xml文件内容:

    taglib    org.zxd1.0.0jar4.0.0taglib-core1.0.0

子模块之间进行互相的依赖

在下面的pom中可以在任意的子模块引入对应的父模块依赖

注意由于 这个标签会递归继承,所以要注意子依赖不要和依赖引入不同版本的依赖,这样容易造成冲突

org.zxd    taglib-core    1.0.0

将上面的项目改造为spring-boot多模块项目:

改造父pom文件:

org.springframework.boot    spring-boot-starter-parent    2.4.0

parent指向 springboot-started

子模块只需要引入父pom的内容

Spring boot maven plugin问题

在打包spring boot项目时,需要使用如下插件:

org.springframework.boot    spring-boot-maven-plugin

如果在用maven构建多模块项目时,不要将此插件放到parent pom中,否则如果有sub module不是spring boot应用,在打包时就会出错。 只将该插件添加到是spring boot项目的子模块

MAVEN依赖冲突问题:

依赖的传递原则:

  1. 最短路径原则
  2. 最先声明原则

maven的依赖引入策略

最短路径原则:

我有下面两个依赖jar包,A和B,他们都引入了C这个依赖,这时候如果有如下的引用

A -> C(3.3)

B -> A(3.3)

B -> C(3.4)

此时如果把B打包,得到版本号是3.4,但是如果B去掉C的依赖,那就是走A->C的传递依赖,很简单

验证:

  1. 我假设我有一个web包引入了common-lang3,版本是3.4的版本
org.apache.commons    commons-lang3    3.4
  1. 此时又引入了一个公用包,里面也有这个引用:
org.apache.commons    commons-lang3    3.3
  1. 如果此时在本地引用3.4版本,那就是3.4的版本,否则就死3.3的版本,不管声明顺序谁先谁后

最先声明原则:

如果两个jar包的寻址路径一致,那么谁先优先声明,先引入谁

验证:

下面两个依赖分配对应两个module,引入模块的这个模块暂定为 C 模块。

org.zxd    taglib-core    1.0.0org.zxd    taglib-db    1.0.0

此时 taglib-core 中的依赖版本如下,暂定为 A 模块:

org.apache.curator    curator-client    2.5.0

而 taglib-db 中的依赖版本如下,暂定为 B 模块:

org.apache.curator    curator-client    4.0.1

此时将整个web项目打包,可以看到web项目里面的版本如下:

可以很明显的看到如果引入关系是这样的:

C -> A,B

A -> curator-client 2.5

B -> curator-client 4.1

这样的链路最终打包出来的效果是 C -> A -> curator-client 2.5

这样也就造成了很多情况下我们 编译运行 时完全没有问题的, 甚至有可能打包都是正常的,但是到最后运行的时候突然报错,要谨防这种依赖版本的问题,好在一般公司的项目都有经理负责控制版本依赖,这种错误算是低级错误,但是在如今框架满天飞的时代,依赖管理的版本控制问题依然需要注意!!!

如何解决依赖冲突的问题

锁定版本法

一般情况下我们会在父pom文件里面管理,可以使用 这个这个标签来管理所有子模块的版本依赖,子模块如果指定自己的版本,这里发现打出来的包依然是父pom指定的版本,版本管理使用如下:

org.apache.curator            curator-client            4.1.0

锁定版本法可以打破2个依赖传递的原则,优先级为最高

版本锁定可以排除一些exclude标签,不同模块用不同版本的jar包本身也不符合规范,所以这种方式较为稳妥

什么情况下会出现Jar包冲突问题

只有高版本Jar包不向下兼容,或者新增了某些低版本没有的API才有可能导致这样的问题

如何查找和发现jar包冲突?

1. 利用idea的maven视图工具

直接使用一个图说明一下:

可以通过这个工具查看依赖在哪个模块重复引用,同时如果有冲突会显示红线,这个视图非常的直观,可以帮助依赖管理人员去处理依赖重复引用或者引用版本不一致的问题,进行 操作

2. Idea Maven Helper 插件

如何使用?

安装完成之后,随便找一个pom.xml文件,按照如下的图例提示进行操作,对于冲突的内容,右击 exclude 就可以排除依赖:

排除完依赖之后,点击左上角的 Refresh UI 刷新一下UI的界面:

3. maven命令工具:

mvn dependency:tree -Dverbose ,有时候如果我们没有idea的情况下,可以使用这个命令来处理,执行的结果参考如下:

PS: 此处一定不要省略 -Dverbose 参数,要不然是 不会 显示被 忽略 的包的

or:curator-client:jar:4.1.0:compile[INFO] |  |  +- org.apache.zookeeper:zookeeper:jar:3.5.4-beta:compile[INFO] |  |  |  +- commons-cli:commons-cli:jar:1.2:compile[INFO] |  |  |  +- log4j:log4j:jar:1.2.17:compile[INFO] |  |  |  +- org.apache.yetus:audience-annotations:jar:0.5.0:compile[INFO] |  |  |  - io.netty:netty:jar:3.10.6.Final:compile[INFO] |  |  +- com.google.guava:guava:jar:20.0:compile[INFO] |  |  - org.slf4j:slf4j-api:jar:1.7.30:compile[INFO] |  +- commons-codec:commons-codec:jar:1.15:compile[INFO] |  +- commons-collections:commons-collections:jar:3.2.2:compile[INFO] |  +- commons-beanutils:commons-beanutils:jar:1.9.4:compile[INFO] |  +- commons-configuration:commons-configuration:jar:1.10:compile[INFO] |  |  - commons-lang:commons-lang:jar:2.6:compile

总体上来说还是比较直观的,非常方便和好用。

如何写一个干净依赖关系的 POM 文件

mvn dependency:analyze-onlymvn dependency:analyze-duplicate

dependency:analyze-only 命令

在idea - Terminal 里面,可以看到对应的依赖被下载

执行完之后我的运行结果如下,这里报错的原因是打包时候默认去阿里云仓库寻找依赖,这里需要配置一下:

[ERROR] Failed to execute goal on project taglib-web: Could not resolve dependencies for project org.zxd:taglib-web:war:1.0.0: The following artifacts could not be resolved: org.zxd:taglib-core:jar:1.0.0, org.zxd:taglib-db:jar:1.0.0: Failure to find org.zxd:taglib-core:jar:1.0.0 in http://maven.aliyun.com/nexus/content/repositories/central/ was cached in the local repository, resolution will not be reattempted until the update interval of alimaven has elapsed or updates are forced -> [Help 1]

大致意思就是说再阿里云仓库找不到对应的依赖引入。

解决方式如下:

找到maven的安装路径下的 apache-maven-3.6.3conf 下面的 setting.xml ,找到如下配置:

  D:softapache-maven-3.6.3ep

此时重新执行一下: dependency:analyze-only 命令

[INFO] --- maven-dependency-plugin:3.1.2:analyze-only (default-cli) @ taglib-web ---[WARNING] Unused declared dependencies found:[WARNING]    org.zxd:taglib-core:jar:1.0.0:compile[WARNING]    org.apache.commons:commons-lang3:jar:3.4:compile[WARNING]    org.springframework.boot:spring-boot-starter-web:jar:2.4.0:compile[WARNING]    org.springframework.boot:spring-boot-starter-test:jar:2.4.0:test[WARNING]    org.neo4j.driver:neo4j-java-driver:jar:1.5.0:compile[WARNING]    commons-codec:commons-codec:jar:1.10:compile[WARNING]    commons-collections:commons-collections:jar:3.2.2:compile[WARNING]    commons-beanutils:commons-beanutils:jar:1.9.4:compile[WARNING]    commons-configuration:commons-configuration:jar:1.10:compile[WARNING]    commons-fileupload:commons-fileupload:jar:1.3:compile[WARNING]    commons-logging:commons-logging:jar:1.2:compile[WARNING]    org.apache.httpcomponents:httpclient:jar:4.4.1:compile[WARNING]    org.apache.poi:poi-ooxml:jar:3.17:compile[WARNING]    org.mybatis:mybatis:jar:3.4.0:compile[WARNING]    org.mybatis:mybatis-spring:jar:1.3.0:compile[WARNING]    com.github.pagehelper:pagehelper:jar:5.1.2:compile

mvn dependency:analyze-duplicate 命令

[INFO] No duplicate dependencies found in  or in 

如果没有其他信息,代表没有重复依赖的引入

来源:https://www.tuicool.com/articles/2UVB3iJ

idea pom依赖失败_maven多模块和依赖冲突问题汇总记录相关推荐

  1. python安装依赖失败_python执行安装第三方依赖numpy失败:error: Unable to find vcvarsall.bat...

    一台计算机上同时安装了python2.7和python3.7. 现在为python2.7安装numpy包. 失败:error: Unable to find vcvarsall.bat ======= ...

  2. python安装依赖失败_python - pip安装jq依赖关系失败 - SO中文参考 - www.soinside.com

    这是我在stackoverflow上的第一个问题.我成功地安装了其他需要的包,如箭头,但我无法安装.jq. https:/pypi.orgprojectjq. 我尝试安装 jq 在Win10上使用此命 ...

  3. maven项目(引入依赖失败, pom.xml 报错\爆红)

    ☺ 引入项目过程中,idea引入磁盘的某个的maven项目 这里以springboot项目以例子,发现pom.xml 的依赖大面积爆红,springboot的版本依赖也报错了,然后发现下面有进度条在下 ...

  4. idea pom依赖失败_IDEA中Maven依赖下载失败的完美解决方案

    使用IDEA进行Maven项目开发时,时不时会遇到pom.xml报错的情况,其中很大概率是因为Maven依赖的jar包下载失败,找来找去也没有找到是什么问题,困扰了很多程序猿,这里给出IDEA中Mav ...

  5. maven pom.xml解析、命令说明、依赖传递、继承、聚合、properties、build、依赖范围、版本仲裁、profile

    maven是当前Java项目中用到最多的依赖管理工具.最开始的项目比较小引入的依赖包也少所以可以通过手动加载jar包的方式来管理依赖包:但随着项目越来越复杂各种大小框架层出不穷,一个项目的开发往往依赖 ...

  6. idea 模块jdk依赖总是自动变为jdk1.5

    转自,IDEA 模块JDK依赖为何总是自动变为JDK1.5, 更好体验:http://www.kongzid.com/ 目录 1.maven的JDK配置 1.1.设置 maven 全局JDK版本(全局 ...

  7. IDEA中使用Maven下载依赖失败的解决办法

    在许多开发者使用IDEA工具开发Maven项目时,经常会遇到maven的Dependecies和pom.xml文件报错,一般这种情况都是jar依赖包下载失败而导致,从而浪费许多开发者和学者的时间.我将 ...

  8. Maven 父pom中dependencyManagement版本优先级高于传递依赖版本

    当使用了传递依赖,也就是使用了没有显示声明的依赖时,如果继承的<dependencyManagement/>中声明了使用的传递依赖的版本,那么最终使用的依赖是<dependencyM ...

  9. 解决 Gradle 进行多模块开发时,模块相互依赖的问题

    问题背景 在使用多模块开发时,通常一个模块(A)可能会需要其它模块(B)中的类或方法,这时就产生了依赖关系,也就是 A 依赖 B. 要解决上述依赖,有两种方案 1.将B发布到 repo 仓库(可以为本 ...

最新文章

  1. 天气预报接口和城市代码
  2. 处理Img标签中src无效时出现的border
  3. python 语句简写_自学Python-语句之列表推导式
  4. python实现文件传输_Python使用socket实现简单的文件传输并校验
  5. JavaScript数组拼接、对象拼接
  6. 罗永浩抖音直播首秀:3小时1.1亿;微软曝三屏折叠机专利;Linux Mint 20仅提供64位版本 | 极客头条...
  7. 夏普 DN7C3A006 PM2.5 传感器测量步骤及存在问题
  8. c jni 调用java_JNI NDK (AndroidStudio+CMake )实现C C++调用Java代码流程
  9. terminal采用公钥免密访问服务器
  10. 计算机学院运动会海报,《图文》运动会宣传海报资料
  11. java大鱼吃小鱼实验报告摘要_java 大鱼吃小鱼游戏总结
  12. BZOJ3876支线剧情
  13. 微型计算机最大的电路板是,微型计算机系统中最大的一块电路板被称作 。
  14. 海康智能分析服务器设置,【胖猴小玩闹】智能门锁与网关: 海康萤石智能门锁的网关分析(三)...
  15. 如何测试服务器性能?
  16. Python-字典学习
  17. 常见机器学习模型适用场景及优缺点
  18. 我的眉画得浓淡可合时兴?打起黄莺儿,莫教枝上啼。
  19. 一个超简单的反编译任务(IDAPro、X32dbg)
  20. 4.BI 探索数据的数据可视化工具

热门文章

  1. 带计算机的笔记本图片,笔记本电脑怎么截图
  2. 【BIM入门实战】Revit 2018幕墙的绘制与注意事项
  3. Subversion的svnsync热备份
  4. python机器学习经典案例_Python机器学习经典实例
  5. 视频画质增强器--v1.0
  6. 学习java之路之第一周html
  7. 前端性能优化——概述(概括前端性能优化入手点)
  8. MySQL注释形式_可执行注释语句(/*!...*/)_数据库注释_数据库脚本注释_SQL脚本注释格式_SQL脚本注释分类
  9. Keil MDK基于标准外设库创建工程和目录图文教程
  10. c语言 两个一元多项式的乘法,一元多项式的加法、减法、乘法和微分运算的C语言链表结构算法实现...