类之间有聚合和继承关系,Maven也具备这种设计原则。

那么Maven的pom是怎样进行聚合与继承的呢?

一、什么是聚合?为什么要用聚合?

上一篇博客介绍了模块化的基本知识。

有了模块化,那么我们项目中会有非常多模块,每一个模块都是独立的maven project,假设项目不大,我们还能够独立的编译測试执行每一个模块,可是随着项目越来越大,我们不得不想办法让我们的工作变得简单,这时就出现了Maven聚合的方式来完毕编译全部模块。

聚合:把多个模块或项目聚合到一期。我们能够建立一个专门负责聚合工作的project.

Maven聚合:当我们的模块许多的时候,我们想要一次构建多个项目。而不是到多个模块的文件夹下分别运行命令。Maven的聚合特性就是为该需求服务的。

Pom.xml:

<parent>
<groupId>com.tgb</groupId>
<artifactId>itoo-root</artifactId>
<version>0.0.1-SNAPSHOT</version>
<!-- 继承itoo-root的pom文件 -->
<relativePath>../itoo-root/pom.xml</relativePath>
</parent> <artifactId>itoo-basic-parent</artifactId>
<packaging>pom</packaging>
<modules>
<module>../itoo-basic-api</module>
<module>../itoo-basic-institution-core</module>
<module>../itoo-basic-institution-web</module>
<module>../itoo-basic-institution-ear</module>
</modules>

Maven约定:

1、首先聚合模块必须为pom。否则无法构建

2、必须有<modules>元素,它是实现聚合的最核心配置。这里能够声明多个module元素。

每一个module的值都是一个当前pom的相对文件夹。

模块所处的文件夹必须和<module>模块所处的文件夹一致。

3、为了方便用户构建项目,通常将聚合模块放在项目文件夹的最顶层,其它模块则作为聚合模块的子文件夹存在。

4、聚合模块的pom没有实质性内容。仅仅有一个pom.xml文件。仅仅是用来帮助其它模块构建的工具。

maven构建:

maven首先解析聚合模块pom、分析要构建的模块、并计算出一个反应堆构建顺序,然后依据这个顺序依次构建各个模块。

反应堆是全部模块组成的一个构建结构。

二、继承

Maven继承也是为了防止反复,让项目的jar包版本号一致,在项目管理上起了非常大的作用。

比方说同样的jar包我们每一个人都须要依赖一遍,而且每一个人引用的版本不同。势必造成项目混乱,执行出问题。

1、子模块省略grouopId和version,都会从父模块依赖下来。

2、子模块元素pom.xml:

<parent>
<groupId>com.tgb</groupId>
<artifactId>itoo-root</artifactId>
<version>0.0.1-SNAPSHOT</version>
<!-- 继承itoo-root的pom文件 -->
<relativePath>../itoo-root/pom.xml</relativePath>
</parent>

随之而来的问题。假设我创建了一个模块不须要依赖父类的依赖。这时候我们须要用Maven的依赖管理来解决问题。即dependencyManagement。见

Maven实战(六)---dependencies与dependencyManagement的差别

三、总结

对于聚合模块来说,它知道有哪些被聚合的模块,而对于被聚合的模块来说。它们不知道被谁聚合了。也不知道它的存在;对于继承关系的pom来说,它不知道被哪些模块继承了,对于子pom来说。它必须知道要继承谁。

总之,聚合是为了方便高速构建项目,继承是为了消除反复配置。在简化pom的同一时候还能促进各个模块配置的一致性。共同点是两者的packaging都是pom,聚合模块与继承关系中的父模块除了pom之外都没有实际内容。

实际项目中我们会发现。一个pom既是聚合pom,也是父pom,这么做主要是为了方便。

Java成功的重要原因之中的一个就是他可以屏蔽大部分操作系统的差异,XML流行的原因之中的一个是全部语言都接受他。Maven用的人越来越多是Maven提倡约定优于配置,这是Maven最核心的设计理念之中的一个。

Maven实战(九)---模块聚合和继承的更多相关文章

  1. (转)Maven学习总结(五)——聚合与继承

    孤傲苍狼只为成功找方法,不为失败找借口! Maven学习总结(五)——聚合与继承 一.聚合 如果我们想一次构建多个项目模块,那我们就需要对多个项目模块进行聚合 1.1.聚合配置代码 1 <mod ...

  2. 【转】Maven实战(九)---模块聚合和继承

    原博文出自于:http://blog.csdn.net/liutengteng130/article/details/47001831   感谢! 类之间有聚合和继承关系,Maven也具备这样的设计原 ...

  3. Maven详解之聚合与继承

    说到聚合与继承我们都很熟悉,maven同样也具备这样的设计原则,下面我们来看一下Maven的pom如何进行聚合与继承的配置实现. 一.为什么要聚合? 随着技术的飞速发展和各类用户对软件的要求越来越高, ...

  4. Maven学习总结(五)——聚合与继承

    一.聚合 如果我们想一次构建多个项目模块,那我们就需要对多个项目模块进行聚合 1.1.聚合配置代码 <modules> <module>模块一</module> & ...

  5. 转】Maven学习总结(五)——聚合与继承

    原博文出自于: http://www.cnblogs.com/xdp-gacl/p/4058008.html 感谢! 一.聚合 如果我们想一次构建多个项目模块,那我们就需要对多个项目模块进行聚合 1. ...

  6. Maven学习小结(四 聚合与继承)

    1.聚合 一次构建多个项目模块. 2.继承 为了消除重复,把很多相同的配置提取出来,例如groupid和version: 2.1 Maven中可以继承的POM元素 groupId :项目组 ID ,项 ...

  7. Maven详解 之 聚合与继承

    说到聚合与继承我们都很熟悉,maven同样也具备这样的设计原则,下面我们来看一下Maven的pom如何进行聚合与继承的配置实现. 一.为什么要聚合? 随着技术的飞速发展和各类用户对软件的要求越来越高, ...

  8. Maven模块聚合与继承

    聚合 假如有account-email和account-persist两个模块,我们想要一次构建这两个项目,这时须要用到聚合. 聚合模块 package值必须为pom 必须有元素modules mod ...

  9. (5)Maven快速入门_5maven聚合与继承_scope依赖范围

    多个maven项目实现统一管理, maven 插件jar继承自父的maven项目.对maven中jar的版本进行管理. 1.创建一个项目来管理多个maven项目 new ----maven Proje ...

随机推荐

  1. 亚马逊AWS免费套餐EC2安装centos连接登录并创建root

    前言:刚开始使用亚马逊的AWS的免费套餐EC2,由于个人习惯使用centos系统,所以果断安装,但是AWS为了安全性,默认禁止用户使用root账户,导致安装配置环境各种问题.所以我把从安好系统后遇到的 ...

  2. C# WCF 完整实例,winform 窗体作为 宿主

    上一次提到,我们的WCF程序宿主是发布到IIS上面的.虽然这样做未尝不可,不过不便于我们进行“开始”或“停止”WCF服务的操作.所以再次尝试了编写以窗体应用程序作为WCF服务宿主的方式,并取得了成功. ...

  3. scala 学习笔记一 列表List

    1.介绍 Scala 列表类似于数组,它们所有元素的类型都相同,但是它们也有所不同:列表是不可变的,值一旦被定义了就不能改变,其次列表 具有递归的结构(也就是链接表结构)而数组不是.. 列表的元素类型 ...

  4. SVN-服务器变更,代码变更

    1.使用<SVN-如何删除 SVN 文件夹下面的小图标>文章中的方法将svn的关联去掉 2.使用<SVN-服务器搭建>文章中visual studio添加项目到svn服务器的步 ...

  5. Linux服务器权限管理之sudo高级应用

    Sudo是允许系统管理员让普通用户执行一些或者全部的root命令的一个工具,减少了root用户的登陆和管理时间,提高了安全性,Sudo不是对shell的一个代替,它是面向每个命令的. Linux系统的 ...

  6. Java Web -- Servlet(5) 开发Servlet的三种方法、配置Servlet具体解释、Servlet的生命周期(2)

    三.Servlet的生命周期 一个Java servlet具有一个生命周期,这个生命周期定义了一个Servlet怎样被加载并被初始化,怎样接收请求并作出对请求的响应,怎样被从服务中清除.Servlet ...

  7. PasswordlessAPI

    passwordlessapiYOURLS允许API调用的老式的方法,使用用户名和密码参数(如果你的设置是私人的,很明显).如果担心将证书发送到野外,还可以使用秘密签名令牌进行API调用.签名的令牌你 ...

  8. C#.NET常见问题(FAQ)-程序不包含适合于入口点的静态“Main”方法怎么办

    如下图所示,一般程序上次运行还好好的,而且不管你复制粘贴再简单的程序也出现这种错误提示.   先点击右侧的显示所有文件,下面列举了所有CS文件,右击点击包括在项目中,则该文件呈现绿色,再运行即可.不过 ...

  9. ZH奶酪:PHP判断图片格式的7种方法

    以图片 $imgurl = "http://www.php10086.com/wp-content/themes/inove/img/readers.gif"; 为例: 思路1. ...

  10. 知识共享图文直播---(一)将数据库中的数据加载到MSFlexGrid空间中再导入Excel

    熟话说万物皆有其存在的道理,为什么我突然想写<知识共享图文直播>这个系列呢?首先,我想的是记录自己学习的历程,在记录中加深自己对知识的理解,同时也希望自己的博文能帮助到其他数据库的初学者. ...