4、Maven坐标的概念以及依赖管理

一 、说明

我们知道maven能帮我们管理jar包,那么它是怎么管理的呢?

二 、什么是坐标?

1、数学中的坐标

  1. 在平面上,使用 X 、Y 两个向量可以唯一的定位平面中的任何一个点
  2. 在空间中,使用 X、Y、Z 三个向量可以唯一的定位空间中的任意一个点

2、Maven 中的坐标

俗称 gav:使用下面三个向量子仓库中唯一定位一个 Maven 工程

在项目中的 pom.xml 文件中,我们可以看到下面gav的定义:

  1. groupid:公司或组织域名倒序
    <groupid>com.wener</groupid>
    
  2. artifactid:模块名,也是实际项目的名称
    <artifactid>webapp</artifactid>
    
  3. version:当前项目的版本
    <version>0.0.1-SNAPSHOT</version>
    <version>0.0.1-RELEASE</version>
    

备注:
在企业的私服中,会存在snapshot快照仓库和release发布仓库,snapshot快照仓库用于保存开发过程中的不稳定版本,release正式仓库则是用来保存稳定的发行版本。
maven会根据模块的版本号(pom文件中的version)中是否带有“-SNAPSHOT”(注意这里必须是全部大写)来判断是快照版本还是正式版本。如果是快照版本,那么在mvn deploy时会自动发布到私服的快照版本库中;如果是正式发布版本,那么在mvn deploy时会自动发布到正式版本库中

三、什么是依赖?

1、概念

如果我们想要在工程中引入某个jar 包,只需要在pom.xml 中引入其jar 包的坐标即可

2、依赖配置

配置信息

  1. <project>
        <dependencies>
            <dependency>
                <groupId></groupId>
                <artifactId></artifactId>
                <version></version>
                <type>...</type>
                <scope>...</scope>
                <optional>...</optional>
                <exclusions>
                    <exclusion>
                      <groupId>...</groupId>
                      <artifactId>...</artifactId>
                    </exclusion>
              </exclusions>
            </dependency>
          </dependencies>
    </project>
    

配置说明

  1. dependencies
    一个 pom.xml 文件中只能存在一个这样的标签。用来管理依赖的总标签
  2. dependency
    包含在dependencies标签中,可以有无数个,每一个表示一个依赖
  3. groupId,artifactId,version:(必要)
    依赖的基本坐标,对于任何一个依赖来说,基本坐标是最重要的,Maven根据坐标才能找到需要的依赖。
  4. type(可选)
    依赖的类型,对应于项目坐标定义的packaging。大部分情况下,该元素不必声明,其默认值是jar。
  5. scope(可选)
    依赖的范围,默认值是 compile
  6. optional(可选)
    标记依赖是否可选
  7. exclusions(可选)
    用来排除传递性依赖,例如jar包冲突

3、依赖的范围(scope)

  1. 说明
    依赖范围就是来控制 classpath(编译、测试、运行) 的关系,maven 的依赖范围有如下几种
  2. 可选值
    • compile
      编译依赖范围。如果没指定,就会默认指定该范围。此依赖范围的 maven 依赖对编译、测试、运行三种 classpath 都有效。
    • test
      测试依赖范围。只对测试 classpath 有效。如,Junit。
    • provided
      已提供依赖范围。此依赖范围对编译和测试 classpath 有效。如, servlet-api,编译和测试的时候需要,但在项目运行的时候,容器会提供,就不需要重复的引入。
    • runtime
      运行时依赖范围。此依赖范围对测试和运行 classpath 有效。如,jdbc 驱动实现,代码编译只需要 jdk 提供的接口就好,测试和运行才需要实际的 jdbc 驱动。
    • system:
      系统范围依赖。此依赖范围对编译和测试 classpath 有效。不要使用
  3. 示意图
    依赖范围 编译classpath有效 测试classpath有效 运行时classpath有效 例子
    compile Y Y Y spring-context
    test N Y N Junit
    provided Y Y N servlet-api
    runtime N Y Y mysql驱动
    system Y Y N 本地的,maven仓库之外的类库文件

4、maven对传递依赖的解析规则。

第一原则:路径最近者优先
如:A->B->C->X(1.0), A->D->X(2.0),对于X构件有2个版本1.0和2.0,因为X(1.0)的依赖长度为3,而X(2.0)的长度为2,所以maven会解析X(2.0)做为当前构件的依赖。
第二原则:第一声明者优先
如果第一原则不能解析依赖。如2个依赖的构件的依赖长度是一样的情况。如A->B->X(1.0)和A->C->X(2.0),X的依赖长度都是2,这时,maven会根据X1.0和X2.0在构件中声明的顺序来决定解析哪个版本。
1、当第二依赖的范围是compile的时候,传递性依赖的范围与第一直接依赖的范围一致。
2、当第二直接依赖的范围是test的时候,依赖不会得以传递。
3、当第二依赖的范围是provided的时候,只传递第一直接依赖范围也为provided的依赖,且传递性依赖的范围同样为 provided;
4、当第二直接依赖的范围是runtime的时候,传递性依赖的范围与第一直接依赖的范围一致,但compile例外,此时传递的依赖范围为runtime;

5、依赖调解

说明

在dependency元素下增加元素exclusions元素。声明一些需要排除的传递性依赖。然后增加对传递性依赖的确切版本的依赖来解决jar版本冲突的问题。解决的方案有两种一种是手动解决, 另外一种是通过maven helper 插件解决

解决方案

手动法
  • 首先分析冲突jar包的依赖路径,使用命令: mvn dependency:tree -Dverbose -Dincludes=commons-logging:commons-loggging,该命令将打印出所有依赖了groupId和artifactId都为commons-logging的jar包的依赖路径。
  • 在两个冲突的版本中,选择一个所需的版本
  • 在pom.xml文件中将冲突的依赖排除,可使用某冲突jar包
maven helper 插件
  • IDEA中安装该插件,选择confilcts,会列出有冲突的jar,右侧在要排除的版本上右键点击Exclude
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容

  • 1、什么是坐标? ①、数学中的坐标 在平面上,使用 X 、Y 两个向量可以唯一的定位平面中的任何一个点 在空间中,...
    goldfather阅读 720评论 0 0
  • |-1-更新内容[6.从仓库解析依赖的机制(重要)] 1Maven仓库作用 仓库用来存储所有项目使用到构件,在ma...
    zlcook阅读 6,022评论 0 25
  • Maven的基本了解 什么是Maven? Maven就是Apache下的一个开源项目。它是用纯java开发的。是一...
    Bcome阅读 2,781评论 0 7
  • maven项目中需要使用到其它依赖时,则需要在pom.xml中配置<dependency>元素也就是依赖声明,这样...
    zlcook阅读 1,802评论 1 3
  • 一、maven的两个作用 项目自动化构建,通过命令行就可以完成整个项目构建过程,不需要我们手动地进行项目构建 管理...
    lifeline张阅读 835评论 0 1