Maven进阶

分模块开发的与设计

分模块开发意义

  • 将原始模块按照功能拆分成若干个子模块,方便模块间的相互调用,接口共享

步骤

  1. 创建Maven模块

  2. 书写模块代码

    • 分模块开发需要先针对模块功能进行设计,在进行编码。不会先将工程开发完毕,然后进行拆分
  3. 通过maven指令安装模块到本地仓库(install指令)

    • 团队内部开发需要发布模块功能到团队内部可共享的仓库中(私服)

依赖管理

依赖管理

  • 依赖指当前项目运行所需的jar,一个项目可以设置多个依赖

  • 格式:

    <dependencies>
      <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>5.3.12</version>
      </dependency>
    </dependencies>
    

依赖传递

  • 依赖具有传递性

    • 直接依赖:在当前项目中通过依赖配置建立的依赖关系

    • 间接依赖:被资源的资源如果依赖其他资源,当前项目的间接依赖其他资源

  • 依赖传递冲突问题

    • 路径优先:当依赖中出项相同的资源时,层级越深,优先级越低,层级越浅,优先级越高
    • 声明优先:当资源在相同层级被依赖时,配置顺序靠前的覆盖配置顺序靠后的
    • 特殊优先:当同级配置了相同资源的不同版本,后配置的覆盖先配置的

可选依赖和排除依赖

可选依赖

  • 可选依赖指对外隐藏当前所依赖的资源——不透明

    <dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.17</version>
        <!--可选依赖时隐藏当前工程所依赖的资源,隐藏后对应资源将不具有依赖传递性-->
        <optional>true</optional>
    </dependency>
    

排除依赖

  • 排除依赖指主动断开依赖的资源,被排除的资源无需指定版本——不需要

    <dependency>
      <groupId>com.xhj</groupId>
      <artifactId>maven_03_pojo</artifactId>
      <version>1.0-SNAPSHOT</version>
      <exclusions>
        <exclusion>
          <groupId>log4j</groupId>
          <artifactId>log4j</artifactId>
        </exclusion>
      </exclusions>
    </dependency>
    
  • 排除依赖资源仅指定GA即可,无需指定V

继承与聚合

聚合

  • 聚合:将多个模块组织成一个整体,同时进行项目构建的过程称为聚合
  • 聚合工程:通常是一个不具有业务功能的“空”工程(有且仅有一个pom文件)
  • 作用:使用聚合工程可以将多个工程编组,通过对聚合工程进行构建,实现对所有包含的模块进行同步构建
    • 当工程中某个模块发生更新(变更)时,必须保障工程中与已更新模块同步更新,此时可以使用聚合工程来解决批量同步构建的问题

步骤

  1. 创建Maven模块,设置打包类型为pom

    <packaging>pom</packaging>
    

    注意事项:每个maven工程都有对应的打包方式,默认为jar,web工程的打包方式为war

  2. 设置当前聚合工程所包含的子模块名称

    <modules>
        <module>../maven_02_ssm</module>
        <module>../maven_03_pojo</module>
    </modules>
    

    注意事项:

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

    参与聚合的工程无法向上感知是否参与聚合,只能向下配置哪些模块参与本工程的聚合

继承

  • 概念:继承描述的是两个工程间的关系,与java中的继承相似,子工程可以继承父工程中的配置信息,常见于依赖关系的描述
  • 作用:
    • 简化配置
    • 减少版本冲突

步骤

  1. 创建Maven模块,设置打包类型为pom

    <packaging>pom</packaging>
    

    建议父工程打包方式设置为pom

  2. 在父工程的pom文件中配置依赖关系(子工程将延用父工程中的依赖关系)

    <dependencies>
      <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>5.3.12</version>
      </dependency>
      <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jdbc</artifactId>
        <version>5.3.12</version>
      </dependency>
      。。。
    </dependencies>
    
  3. 配置子工程可以选择的依赖关系

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>junit</groupId>
                <artifactId>junit</artifactId>
                <version>4.13.2</version>
                <scope>test</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
    
  4. 在子工程中配置当前工程所继承的父工程

    <parent>
        <groupId>com.xhj</groupId>
        <artifactId>maven_01_parent</artifactId>
        <version>1.0-SNAPSHOT</version>
        <!--定位,不写也可以-->
        <relativePath>../maven_01_parent/pom.xml</relativePath>
    </parent>
    
  5. 在子工程配置使用父工程中可选依赖的坐标

    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <scope>test</scope>
    </dependency>
    

    注意事项

    • 子工程中使用父工程中的可选依赖时,仅需要提供群组id和项目id,无需提供版本,版本由父工程统一提供,避免版本冲突
    • 子工程还可以定义父工程中没有定义的依赖关系

聚合与继承的区别

  • 作用
    • 聚合用户快速构建项目
    • 继承用于快速配置
  • 相同点:
    • 聚合与继承的pom.xml文件打包方式均为pom,可以将两种关系制作到同一种pom文件中
    • 聚合与继承均属于设计模块,并无实际的模块内容
  • 不同点:
    • 聚合是在当前模块中配置关系,聚合可以感知到参与聚合的模块有哪些
    • 继承是在子模块中配置关系,父模块无法感知哪些子模块继承了自己

属性

  1. 定义属性

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    
        <spting.version>5.3.12</spting.version>
    
    </properties>
    
  2. 引用属性

    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>${spting.version}</version>
    </dependency>
    

资源文件引用属性

  1. 定义属性

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
        
        <spting.version>5.3.12</spting.version>
    
        <jdbc.url>jdbc:mysql://127.0.0.1:3305/ssm_bd</jdbc.url>
    </properties>
    
  2. 配置文件中引用属性

    jdbc.driver=com.mysql.cj.jdbc.Driver
    jdbc.url=${jdbc.url}
    jdbc.username=****
    jdbc.password=*****
    
  3. 开启资源文件目录加载的过滤器

    <build>
        <resources>
            <resource>
                <directory>${project.basedir}/src/main/resources</directory>
                <filtering>true</filtering>
            </resource>
        </resources>
    </build>
    
  4. 配置maven打war包时,忽略web.xml检查

    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-war-plugin</artifactId>
            <version>3.2.2</version>
            <configuration>
                <failOnMissingWebXml>false</failOnMissingWebXml>
            </configuration>
        </plugin>
    </plugins>
    

其他属性(了解)

  • 属性列表

    1. 自定义属性
    2. 内置属性
    3. Setting属性
    4. Java系统属性
    5. 环境变量属性

版本管理

  • 工程版本:
    • SNAPSHOT:(快照版本)
      • 项目开发过程中临时输出的版本,称为快照版本
      • 快照版本会随着开发的进展不断更新
    • RELSASE(发布版本)
      • 项目开发到进入阶段里程碑后,向团队外部发布较为稳定的版本,这种版本所对应的结果文件时稳定的,即使进行功能的后续开发,也不会改变当前发布版本的内容,这种版本称为发布版本
  • 发布版本
    • alpha版
    • beta版
    • 纯数字版

多环境配置与应用

多环境开发

  • maven提供配置多种环境配置的设定,版主开发者使用过程中快速切换环境
  1. 定义多环境

    <!--配置多环境-->
    <profiles>
        <!--开发环境-->
        <profile>
            <id>env_dep</id>
            <properties>
                <jdbc.url>jdbc:mysql://127.1.1.1:3305/ssm_bd</jdbc.url>            </properties>
        </profile>
        <!--生产环境-->
        <profile>
            <id>env_pro</id>
            <properties>
                <jdbc.url>jdbc:mysql://127.2.2.1:3305/ssm_bd</jdbc.url>            </properties>
        </profile>
        <!--测试环境-->
        <profile>
            <id>env_test</id>
            <properties>
                <jdbc.url>jdbc:mysql://127.3.3.1:3305/ssm_bd</jdbc.url>            </properties>
        </profile>
    </profiles>
    
  2. 使用多环境(构建过程)

跳过测试

  • 场景应用

    • 功能更新中并且没有开发完毕
    • 快速打包
    • ......
  • 跳过测试

  • 范例

    注意事项

    执行的项目构建指令必须包含测试生命周期,否则无效。例如执行compile生命周期,不经过test生命周期

  • 细粒度控制跳过测试

    <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-surefire-plugin</artifactId>
        <version>2.22.2</version>
        <configuration>
            <skipTests>true</skipTests>
            <!--包含指定的测试用例-->
            <includes>
                <include>**/User*TestCase.java</include>
            </includes>
            <excludes>
                <!--排除指定的测试用例-->
                <exclude>**/User*Test.java</exclude>
            </excludes>
        </configuration>
    </plugin>
    

私服

团队开发现状分析

私服简介

  • 私服是一台独立的服务器,用于解决团队内部的资源共享与资源同步问题

  • Nexus

  • 启动服务器(命令行启动)

    nexus.exe /run nexus
    
  • 访问服务器(默认端口:8081)

    http://localhost:8081
    
  • 修改基础配置信息

    • 安装路径下etc目录中nexus-default.properties文件保存有nexus基础配置信息,例如默认访问端口
  • 修改服务器运行配置信息

    • 安装路径下bin目录中nexus.vmoptions文件保存有nexus服务器启动对应的配置信息,例如默认占用内存空间