Maven高级操作--分模块设计、聚合、继承和私服

一、分模块设计与开发

1.1 分模块设计

  • 问题:当项目做大做强的时候,前面的基础Spring开发的框架都无法满足java大型项目的维护和复用,而且团队合作也会造成较大的困难。
  • 所以就需要分模块设计:将项目按照功能拆分成若干个子模块,方便项目的管理维护扩展,也方便模块间的相互调用资源共享

分模块开发需要先针对模块功能进行设计,再进行编码。不会先将工程开发完毕,然后进行拆分。

  • 大概步骤:
  1. 创建一个新的maven项目,并填写需要分出去的模块名。
  2. 在原项目下将模块的包,如utils包下的类,放到目标maven项目下,目录名字保持一致main\java\com\mannor\utlis
  3. 将需要的依赖项导入到新maven中。
  4. 将新maven导入到原来的项目pom.xml文件中,即可食用。

二、继承与聚合

2.1 继承

  • 概念:继承描述的是两个工程间的关系,与java中的继承相似,子工程*可以继承父工程中的配置信息,常见于依赖关系的继承**。
  • 作用:简化依赖配置、统一管理依赖
  • 实现: ...

2.1.1 继承关系的实现

  1. 创建maven模块tlias-parent,该工程为父工程,设置打包方式**pom**(默认jar)。
    
	
    <parent>
        <groupId>org.springframework.bootgroupId>
        <artifactId>spring-boot-starter-parentartifactId>
        <version>2.7.12version>
        <relativePath/> 
    parent>

    <groupId>com.mannorgroupId>
    <artifactId>tlias-parentartifactId>
    <version>0.0.1-SNAPSHOTversion>
    <packaging>pompackaging> 

project>

  1. 子工程pom.xml文件中,配置继承关系。
    
  <parent>
        <groupId>com.mannorgroupId>
        <artifactId>tlias-parentartifactId>
        <version>0.0.1-SNAPSHOTversion>
        <relativePath>../tlias-parent/pom.xmlrelativePath> 
    parent>

    <artifactId>tlias-web-managementartifactId>
    <version>0.0.1-SNAPSHOTversion>
    <name>tlias-web-managementname>
    <description>tlias-web-managementdescription>
  1. 父工程中配置各个工程共有的依赖(子工程会自动继承父工程的依赖)。
  • 代码展示略。

2.1.1.1 继承关系图

Maven高级操作--分模块设计、聚合、继承和私服_第1张图片

2.1.1.2 重点

  1. 在子工程中,配置了继承关系之后,坐标中的groupId是可以省略的,因为会自动继承父工程的。
  2. relativePath指定父工程的pom文件的相对位置(如果不指定,将从本地仓库/远程仓库查找该工程)。
  3. 若父子工程都配置了同一个依赖的不同版本,以子工程的为准。

常见的打包方式:
jar:普通模块打包,springboot项目基本都是jar包(内嵌tomcat运行)
war:普通web程序打包,需要部署在外部的tomcat服务器中运行
pom:父工程或聚合工程,该模块不写代码,仅进行依赖管理

2.1.2 版本锁定

2.1.2.1 版本管理

  • 在maven中,可以在父工程的pom文件中通过来统一管理依赖版本。
  • 子工程引入依赖时,无需指定版本号,父工程统一管理。变更依赖版本,只需在父工程中统一变更。
  1. 在父工程中:
 
    <dependencyManagement>
        <dependencies>

            
            <dependency>
                <groupId>io.jsonwebtokengroupId>
                <artifactId>jjwtartifactId>
                <version>0.9.1version>
            dependency>
			
        dependencies>
    dependencyManagement>
  1. 在子工程中直接引用即可,无需指定版本号:
    <dependencies> 

        
        <dependency>
            <groupId>io.jsonwebtokengroupId>
            <artifactId>jjwtartifactId>
        dependency>

    dependencies>

2.1.2.2 自定义属性/引用属性

  • 在大型开发中,会有许多依赖需要引用,所以有自定义属性来直接管理版本信息,更方便后期的维护。
  1. 自定义属性:
    <properties>
        <lombok.version>1.18.24lombok.version>
    properties>
  1. 引用属性
    <dependencies>
        <dependency>
            <groupId>org.projectlombokgroupId>
            <artifactId>lombokartifactId>
            <version>${lombok.version}version>
        dependency>
    dependencies>

思考?的区别是什么?
1.是直接依赖,在父工程配置了依赖,子工程会直接继承下来。
2.>`是统一管理依赖版本,不会直接依赖,还需要在子工程中引入所需依赖(无需指定版本)

2.2 聚合

  • 当项目开发完毕时,要对目标工程执行打包的操作。目标工程会在本地的maven仓库中去寻找对应依赖的jar包,不然就不会构建成功。
  • 要想将jar包放到maven的本地仓库就要按照顺序执行对应maven项目或者模块的install操作,这样才会打包成功。

当然这种方式的缺点也很明显,就是当项目模块的数量很多的时候就不便于操作了。所以就需要maven的聚合。

2.2.1 概念

2.2.1.1 聚合:

  • 将多个模块组织成一个整体,同时进行项目的构建。

2.2.1.2 聚合工程

  • 一个不具有业务功能的“空”工程(有且仅有一个pom文件)---->parent父工程就刚好可以充当这样得到角色。

2.2.1.3. 作用

  • 快速构建项目(无需根据依赖关系手动构建,直接在聚合工程上构建即可)

2.2.2 操作实现

  • maven中可以通过设置当前聚合工程所包含的子模块名称

聚合工程中所包含的模块,在构建时,会自动根据模块间的依赖关系设置构建顺序,与聚合工程中模块的配置书写位置无关。

  • 源码实现,在父工程的pom.xml文件下:
    
    <modules>
        <module>../tlias-pojomodule>   
        <module>../tlias-utlismodule>
        <module>../tlias-web-managementmodule>
    modules>
  • 最后操作:执行父工程的install或clean等指令和程序。

2.3 继承与聚合的区别

2.3.1 作用

  • 聚合用于快速构建项目
  • 继承用于简化依赖配置、统一管理依赖

2.3.2 相同点:

  • 聚合与继承的pom.xml文件打包方式均为pom,可以将两种关系制作到同一个pom文件中聚合与继承均属于设计型模块,并无实际的模块内容

2.3.3 不同点:

  • 聚合是在聚合工程中配置关系,聚合可以感知到参与聚合的模块有哪些继承是在子模块中配置关系,父模块无法感知哪些子模块继承了自己

三、maven的私服

1.介绍

  • 私服是一种特殊的远程仓库,它是架设在局域网内的仓库服务,用来代理位于外部的中央仓库,用于解决团队内部的资源共享与资源同步问题。
  • 依赖查找顺序:–>本地仓库–>私服–>中央仓库

私服在企业项目开发中,一个项目/公司,只需要一台即可(无需我们自己搭建,会使用即可)。

2.资源的上传和下载

Maven高级操作--分模块设计、聚合、继承和私服_第2张图片

  • 项目版本:
    • RELEASE(发行版本)︰功能趋于稳定、当前更新停止,可以用于发行的版本,存储在私服中的RELEASE仓库中。
    • SNAPSHOT(快照版本)︰功能不稳定、尚处于开发中的版本,即快照版本,存储在私服的SNAPSHOT仓库

3.具体操作

  1. 设置私服的访问用户名/密码(settings.xml中的servers中配置)。
  2. IDEA的maven工程的pom文件中配置上传(发布)地址。
  3. 设置私服依赖下载的仓库组地址(settings.xml中的mirrors、profiles中配置。

因为私服的信息配置都是固定的步骤,所以我将私服的配置操作在此省略,单独写成md文件,需要的可以私我发你。

你可能感兴趣的:(后端,maven,python,java)