认识maven多模块

介绍

Maven多模块项目,适用于一些比较大的项目,通过合理项目拆分,实现代码的复用,便于维护的管理,尤其是一些开源的框架,也是采用多模块的方式,提供插件集成,用户可以根据配置指定的模块。

拆分规则

业务模块拆分

在这里插入图片描述

按层拆分

在这里插入图片描述

聚合、继承

1>聚合

我们在开发过程中,创建了2个以上的模块,每个模块都是一个独立的maven project,在开始的时候我们可以独立的编译和测试运行每个模块,但是随着项目的不断变大和复杂化,我们期望能够使用简单的操作来完成编译等工作,这时Maven给出了聚合的配置方式。
所谓聚合,顾名思义,就是把多个模块或项目聚合到一起,我们可以建立一个专门负责聚合工作的Maven 工程。

建立该project的时候,我们要注意以下几点:

  1. 聚合模块本身也做为一个Maven项目,它必须有自己的POM
  2. 它的打包方式必须为: pom
  3. 引入了新的元素:modules—module
  4. 版本:聚合模块的版本和被聚合模块版本一致
  5. 相对目录:每个module的值都是一个当前POM的相对目录
  6. 目录名称:为了方便的快速定位内容,模块所处的目录应当与其artifactId一致(Maven约定而不是硬性要求),总之,模块所处的目录必须和模块所处的目录相一致。
  7. 习惯约定:为了方便构建,通常将聚合模块放在项目目录层的最顶层,其它聚合模块作为子目录存在。这样当我们打开项目的时候,第一个看到的就是聚合模块的POM
  8. 聚合模块减少的内容:聚合模块的内容仅仅是一个pom.xml文件,它不包含src/main/Java、src/test/java等目录,因为它只是用来帮助其它模块构建的工具,本身并没有实质的内容。
  9. 聚合模块和子模块的目录:他们可以是父子类,也可以是平行结构,当然如果使用平行结构,那么聚合模块的POM也需要做出相应的更改。

2>继承

我们在项目开发的过程中,可能多个模块独立开发,但是多个模块可能依赖相同的元素,比如说每个模块都需要Junit,使用spring的时候,其核心jar也必须都被引入,在编译的时候,maven-compiler-plugin插件也要被引入。这时我们采用继承,就不用在每个子模块分别定义了。

如何配置继承

  1. 说到继承肯定是一个父子结构,那么我们在父工程中来创建一个parent project
  2. : 作为父模块的POM,其打包类型也必须为POM
  3. 结构:父模块只是为了帮助我们消除重复,所以它也不需要src/main/java、src/test/java等目录
  4. 新的元素: , 它是被用在子模块中的
  5. parent>元素的属性:: 表示父模块POM的相对路径,在构建的时候,Maven会先根据relativePath检查父POM,如果找不到,再从本地仓库查找
  6. relativePath的默认值: …/pom.xml
  7. 子模块省略groupId和version: 使用了继承的子模块中可以不声明groupId和version, 子模块将隐式的继承父模块的这两个元素

3>聚合与继承的区别

在这里插入图片描述

聚合和继承通常是结合使用的,但是其作用是不同的。聚合是将多个模块的工程汇聚到一起,而继承则是指明某个模块工程要继承另一个模块功能。

pom、war、jar类型的使用

1. pom工程:用在父级工程或聚合工程中。用来做jar包的版本控制。

是整个项目的父工程,它是一个pom工程。用来做整个项目的版本控制,也就是项目中所有要使用到的jar包的版本都集中由父工程管理。这样你在写其他工程pom文件中maven依赖时就不需要写版本号了。当然所有的项目都要先继承它才行。

2. war工程:将会打包成war,发布在服务器上的工程。如网站或服务。

这些工程都是要部署在服务器上的,所以要打包成war形式。这些工程有的是用户通过浏览器直接访问,有的是通过发布服务被别的工程调用。

3. jar工程:将会打包成jar用作jar包使用。

这个就是打包成jar的工程。它就是存放一些其他工程都会使用的类,工具类。我们可以在其他工程的pom文件中去引用它,和引用别的jar包没什么区别。

如何依赖

  1. DepencyManagement应用场景
    当我们的项目模块很多的时候,我们使用Maven管理项目非常方便,帮助我们管理构建、文档、报告、依赖、scms、发布、分发的方法。可以方便的编译代码、进行依赖管理、管理二进制库等等。由于我们的模块很多,所以我们又抽象了一层,抽出一个itoo-base-parent来管理子项目的公共的依赖。为了项目的正确运行,必须让所有的子项目使用依赖项的统一版本,必须确保应用的各个项目的依赖项和版本一致,才能保证测试的和发布的是相同的结果。在我们项目顶层的POM文件中,我们会看到dependencyManagement元素。通过它元素来管理jar包的版本,让子项目中引用一个依赖而不用显示的列出版本号。Maven会沿着父子层次向上走,直到找到一个拥有dependencyManagement元素的项目,然后它就会使用在这个dependencyManagement元素中指定的版本号。
  2. Dependencies
    相对于dependencyManagement,所有生命在dependencies里的依赖都会自动引入,并默认被所有的子项目继承
    3、区别
    dependencies即使在子项目中不写该依赖项,那么子项目仍然会从父项目中继承该依赖项(全部继承)dependencyManagement里只是声明依赖,并不实现引入,因此子项目需要显示的声明需要用的依赖。如果不在子项目中声明依赖,是不会从父项目中继承下来的;只有在子项目中写了该依赖项,并且没有指定具体版本,才会从父项目中继承该项,并且version和scope都读取自父pom;另外如果子项目中指定了版本号,那么会使用子项目中指定的jar版本。

猜你喜欢

转载自blog.csdn.net/weixin_43681813/article/details/88664784
今日推荐