美文网首页
maven的继承与聚合

maven的继承与聚合

作者: boyiis | 来源:发表于2024-04-29 17:12 被阅读0次

    继承和聚合的主要作用
    聚合 用于快速构建项目
    继承 用于简化依赖配置、统一管理依赖

    一、分模块设计与开发

    1.为什么要使用分模块设计?

    将项目按照功能拆分成若干个子模块,方便项目的管理维护、扩展,也方便模块间的相互调用,资源共享。

    2.分模块开发步骤:

    • 创建maven模块 tlias-pojo,存放实体类。
    • 创建maven模块 tlias-utils,存放相关工具类。

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

    分模块

    3.小结:

    3.1.什么是分模块设计?

    将项目按照功能拆分成若干个子模块

    3.2.为什么要分模块设计?

    方便项目的管理维护、扩展,也方便模块间的相互调用,资源共享

    3.3.注意事项

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

    二、继承与聚合

    1.继承

    1.1.继承关系

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

    image.png

    继承关系实现步骤:
    ①. 创建maven模块 tlias-parent ,该工程为父工程,设置打包方式pom(默认jar)。
    jar:普通模块打包,springboot项目基本都是jar包(内嵌tomcat运行)
    war:普通web程序打包,需要部署在外部的tomcat服务器中运行
    pom:父工程或聚合工程,该模块不写代码,仅进行依赖管理
    ②. 在子工程的pom.xml文件中,配置继承关系。
    ③. 在父工程中配置各个工程共有的依赖(子工程会自动继承父工程的依赖)。

    image.png

    ①. 创建maven模块 tlias-parent ,该工程为父工程,设置打包方式pom。

    <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>2.7.5</version>
      <relativePath/>
    </parent>
    
    <groupId>com.zhe</groupId>
    <artifactId>tlias-parent</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>pom</packaging>
    

    ②. 在子工程的pom.xml文件中,配置继承关系。


    image.png

    注意事项:
    在子工程中,配置了继承关系之后,坐标中的groupId是可以省略的,因为会自动继承父工程的 。
    relativePath指定父工程的pom文件的相对位置(如果不指定,将从本地仓库/远程仓库查找该工程)。

    ③. 在父工程中配置各个工程共有的依赖(子工程会自动继承父工程的依赖)

    <dependencies>
      <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <version>1.18.24</version>
      </dependency>
    </dependencies>
    

    注意事项:
    若父子工程都配置了同一个依赖的不同版本,以子工程的为准。

    小结:
    maven项目父子工程结构说明:

    1
    2

    1.2.版本锁定

    在maven中,可以在父工程的pom文件中通过 <dependencyManagement> 来统一管理依赖版本。

    父工程:

    <dependencyManagement>
      <dependencies>
        <!--JWT令牌-->
        <dependency>
          <groupId>io.jsonwebtoken</groupId>
          <artifactId>jjwt</artifactId>
          <version>0.9.1</version>
        </dependency>
      </dependencies>
    </dependencyManagement>
    

    子工程:

    <dependencies>
      <dependency>
        <groupId>io.jsonwebtoken</groupId>
        <artifactId>jjwt</artifactId>
      </dependency>
    </dependencies>
    

    注意事项:
    子工程引入依赖时,无需指定 <version> 版本号,父工程统一管理。变更依赖版本,只需在父工程中统一变更。

    1.3.自定义属性/引用属性

    自定义属性/引用属性

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

    2. 聚合

    聚合
    聚合:将多个模块组织成一个整体,同时进行项目的构建。
    聚合工程: 一个不具有业务功能的“空”工程(有且仅有一个pom文件)
    作用:快速构建项目(无需根据依赖关系手动构建,直接在聚合工程上构建即可)

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

    父工程(聚合工程):

    <!--聚合-->
    <modules>
      <module>../tlias-pojo</module>
      <module>../tlias-utils</module>
      <module>../tlias-web-management</module>
    </modules>
    

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

    继承与聚合小结
    作用:
    聚合用于快速构建项目
    继承用于简化依赖配置、统一管理依赖

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

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

    三、私服

    介绍:私服是一种特殊的远程仓库,它是架设在局域网内的仓库服务,用来代理位于外部的中央仓库,用于解决团队内部的资源共享与资源同步问题。

    私服

    依赖查找顺序:
    1.本地仓库
    2.私服
    3.中央仓库

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

    资源上传与下载

    资源上传与下载

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

    私服配置步骤说明:
    访问私服:http://192.168.150.101:8081
    访问密码:admin/admin

    使用私服,需要在maven的settings.xml配置文件中,做如下配置:

    1. 需要在 servers 标签中,配置访问私服的个人凭证(访问的用户名和密码)
    <server>
        <id>maven-releases</id>
        <username>admin</username>
        <password>admin</password>
    </server>
    
    <server>
        <id>maven-snapshots</id>
        <username>admin</username>
        <password>admin</password>
    </server>
    
    1. 在 mirrors中只配置我们自己私服的连接地址(如果之前配置过阿里云,需要直接替换掉)
    <mirror>
        <id>maven-public</id>
        <mirrorOf>*</mirrorOf>
        <url>http://192.168.150.101:8081/repository/maven-public/</url>
    </mirror>
    
    1. 需要在 profiles 中,增加如下配置,来指定snapshot快照版本的依赖,依然允许使用
    <profile>
        <id>allow-snapshots</id>
            <activation>
                <activeByDefault>true</activeByDefault>
            </activation>
        <repositories>
            <repository>
                <id>maven-public</id>
                <url>http://192.168.150.101:8081/repository/maven-public/</url>
                <releases>
                    <enabled>true</enabled>
                </releases>
                <snapshots>
                    <enabled>true</enabled>
                </snapshots>
            </repository>
        </repositories>
    </profile>
    
    1. 如果需要上传自己的项目到私服上,需要在项目的pom.xml文件中,增加如下配置,来配置项目发布的地址(也就是私服的地址)
    <distributionManagement>
        <!-- release版本的发布地址 -->
        <repository>
            <id>maven-releases</id>
            <url>http://192.168.150.101:8081/repository/maven-releases/</url>
        </repository>
    
        <!-- snapshot版本的发布地址 -->
        <snapshotRepository>
            <id>maven-snapshots</id>
            <url>http://192.168.150.101:8081/repository/maven-snapshots/</url>
        </snapshotRepository>
    </distributionManagement>
    
    1. 发布项目,直接运行 deploy 生命周期即可 (发布时,建议跳过单元测试)


      image.png

    启动本地私服

    1. 解压: apache-maven-nexus.zip
    2. 进入目录: apache-maven-nexus\nexus-3.39.0-01\bin
    3. 启动服务:双击 start.bat
    4. 访问服务:localhost:8081
    5. 私服配置说明:将上述配置私服信息的 192.168.150.101 改为 localhost

    相关文章

      网友评论

          本文标题:maven的继承与聚合

          本文链接:https://www.haomeiwen.com/subject/ciotfjtx.html