0%

Maven

Maven项目对象模型(POM),可以通过一小段描述信息来管理项目的构建,报告和文档的项目管理工具软件,用来项目构建和依赖管理。

Maven基础入门

Maven的概念
  • Maven的本质是一个项目管理工具,将项目开发和管理过程抽象成一个项目对象模型(POM)
  • POM(Project Object Model):项目对象模型
Maven的作用
  • 项目构建:提供标准的、跨平台的自动化项目构建方式
  • 依赖管理:方便快捷的管理项目依赖的资源(jar包),避免资源间的版本冲突问题
  • 统一开发结构:提供标准的、统一的项目结构
仓库
  • 仓库:用于存储资源,包含各种jar包
  • 仓库分类:
    • 本地仓库:自己电脑上存储资源的仓库,连接远程仓库获取资源
    • 远程仓库:非本机电脑上的仓库,为本地仓库提供资源
      • 中央仓库:Maven团队维护,存储所有资源的仓库
      • 私服:部门/公司范围内存储资源的仓库,从中央仓库获取资源
  • 私服的作用:
    • 保存具有版权的资源,包含购买或自主研发的jar
      • 中央仓库的jar都是开源的,不能存储具有版权的资源
    • 一定范围内共享资源,仅对内部开放,不对外共享
坐标
  • 什么是坐标?

    Maven中的坐标用于描述仓库中资源的位置

    https://repo1.maven.org/maven2/

  • Maven坐标主要组成

    groupId:定义当前Maven项目隶属组织名称(通常是域名反写,例如:org.mybatis)

    artifactId:定义当前Maven项目名称(通常是模块名称,例如CRM、SMS)

    version:定义当前项目版本号

    packaging:定义该项目的打包方式

Maven项目构建命令

Maven构建命令使用mvn开头,后面添加功能参数,可以一次执行多个命令,使用空格分隔

1
2
3
4
5
mvn compile #编译
mvn clean #清理
mvn test #测试
mvn package #打包
mvn install #安装到 本地仓库
Maven插件创建工程
创建java工程
1
mvn archetype:generate -DgroupId={project-packaging} -DartifactId={project-name} -DarchetypeArtifactId=maven-archetype-quickstart -Dversion={version} -DinteractiveMode=false
创建web工程
1
mvn archetype:generate -DgroupId={project-packaging} -DartifactId={project-name} -DarchetypeArtifactId=maven-archetype-webapp -Dversion={version} -DinteractiveMode=false
依赖管理
依赖配置
  • 依赖指当前项目运行所需的jar,一个项目可以设置多个依赖
  • 格式
1
2
3
4
5
6
7
8
9
10
11
12
<!-- 设置当前项目所依赖的所有jar -->
<dependencies>
<!--设置具体的依赖-->
<dependency>
<!--依赖所属群组id -->
<groupId>junit</groupId>
<!--依赖所属项目id-->
<artifactId>junit</artifactId>
<!--依赖版本号-->
<version>4.11</version>
</dependency>
</dependencies>
依赖传递
  • 依赖具有传递性
    • 直接依赖:在当前项目中通过依赖配置建立的依赖关系
    • 间接依赖:被依赖的资源如果依赖其他资源,当前项目间接依赖其他资源
依赖传递冲突问题
  • 路径优先:当依赖中出现相同的资源时,层级越深,优先级越低,层级越浅,优先级越高

  • 声明优先:当资源在相同层级被依赖时,配置顺序靠前的覆盖配置顺序靠后的

  • 特殊优先:当同级配置了相同资源的不同版本,后配置的覆盖先配置的

可选依赖
  • 可选依赖指对外隐藏当前所依赖的资源——不透明
1
2
3
4
5
6
<dependency>
<groupId>junit></groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<optional>true</optional>
</dependency>
排除依赖
  • 排除依赖指主动断开依赖的资源,被排除的资源无需制定版本——不需要
1
2
3
4
5
6
7
8
9
10
11
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<exclusions>
<exclusion>
<groupId>org.hamcrest</groupId>
<artifactId>hamcrest-core</artifactId>
</exclusion>
<exclusions>
</dependency>
依赖范围
  • 依赖的jar默认情况可以在任何地方使用,可以通过scope标签设定其作用范围
  • 作用范围
    • 主程序范围有效(main文件夹范围内)
    • 测试程序范围有效(test文件夹范围内)
    • 是否参与打包(package指令范围内)
scope 主代码 测试代码 打包 范例
compile(默认) Y Y Y log4j
test Y junit
provided Y Y servlet-api
runtime Y jdbc
生命周期与插件
项目构建生命周期
  • Maven对项目构建的生命周期划分为3套
    • clean:清理工作
    • default:核心工作,例如编译,测试,打包,部署等
    • site:产生报告,发布站点等
插件
  • 插件与生命周期内的阶段绑定,在执行到对应生命周期时执行对应的插件功能
  • 默认maven在各个生命周期上绑定有预设的功能
  • 通过插件可以自定义其他功能
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<build>
<plugins>
<plugin>
<groudId>org.apache.maven.plugins</groupId>
<artifactId>maven-source-plugin</artifactId>
<version>2.2.1</version>
<executions>
<execution>
<goals>
<goal>jar</goal>
</goals>
<phase>generate-test-resources</phase>
</execution>
</executions>
</plugin>
</plugins>
</build>

Maven高级

  • pojo模块拆分
  • dao模块拆分
  • service模块拆分
  • controller模块拆分
分模块开发与设计
  • 模块中仅包含当前模块对应的功能类与配置文件
  • spring核心配置根据模块功能不同进行独立制作
  • 当前模块所依赖的模块通过导入坐标的形式加入当前模块后才可以使用
  • web.xml需要加载所有的spring核心配置文件
继承和聚合
继承
  • 作用:聚合用于快速构建maven工程,一次性构建多个项目/模块

  • 制作方式:

    • 创建一个空模块,打包类型定义为pom
    1
    <packaging>pom</packaging>
    • 定义当前模块进行构建操作时关联的其他模块名称
    1
    2
    3
    4
    5
    6
    <modules>
    <module>../ssm_controller</module>
    <module>../ssm_service</module>
    <module>../ssm_dao</module>
    <module>../ssm_pojo</module>
    </modules>
  • 注意事项:参与聚合操作的模块最终执行顺序与模块间的依赖关系有关,与配置顺序无关

继承
  • 作用:通过继承可以实现在子工程中沿用父工程中的配置

    • maven中的继承与java中的继承相似,在子工程中配置继承关系
  • 制作方式:

    • 在子工程中声明其父工程坐标与对应的位置
    1
    2
    3
    4
    5
    6
    7
    8
    <!--定义该工程的父工程-->
    <parent>
    <groupId>com.z2bns</groupId>
    <artifactId>ssm</artifactId>
    <version>1.0-SNAPSHOT</version>
    <!-- 填写父工程的pom文件-->
    <relativePath>../ssm/pom.xml</relativePath>
    </parent>
    • 在父工程中定义依赖管理
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    <!-- 声明此处进行依赖管理-->
    <dependencyManagement>
    <!--具体的依赖-->
    <dependencies>
    <!--spring环境-->
    <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-context</artifactId>
    <version>5.1.9.RELEASE</version>
    </denpendency>
    </dependencies>
    <dependencyManagement>
    • 在子工程中定义依赖关系,无需声明依赖版本,版本参照父工程中依赖的版本
    1
    2
    3
    4
    5
    6
    7
    <dependencies>
    <!--spring环境-->
    <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-context</artifactId>
    </dependency
    </dependencies>
继承和聚合比较
  • 作用
    • 聚合用于快速构建项目
    • 继承用于快速配置
  • 相同点:
    • 聚合与继承的pom.xml文件打包方式均为pom,可以将两种关系制作到同一个pom文件中
    • 聚合与继承均属于设计型模块,并无实际的模块内容
  • 不同点
    • 聚合是在当前模块中配置关系,聚合可以感知到参与聚合的模块有哪些
    • 继承是在子模块中配置关系,父模块无法感知哪些子模块继承了自己
属性
自定义属性
  • 作用

    • 等同于定义变量,方便统一维护
  • 定义格式:

    1
    2
    3
    4
    <!--定义自定义属性-->
    <properties>
    <spring.version>5.1.9.RELEASE</spring.version>
    </properties>
  • 调用格式

    1
    2
    3
    4
    5
    <dependency>
    <groupId>org.springframework</groupId>
    <artifactId>spring-context</artifactId>
    <version>${sprint.version}</version>
    </dependency>
内置属性
Setting属性
Java系统属性
环境变量属性
版本管理
工程版本
  • SNAPSHOT(快照版本)

    • 项目开发过程中,为方便团队成员合作,解决模块间相互依赖和时时更新的问题,开发者对每个模块进行构建的时候,输出的临时性版本叫快照版本(测试阶段版本)
    • 快照版本会随着开发的进展不断更新
  • RELEASE(发布版本)

    • 项目开发到进入阶段里程碑后,向团队外部发布较为稳定的版本,这种版本所对应的构建文件时稳定的,即便进行功能的后续开发,也不会改变当前发布版本内容,这种版本称为发布版本
工程版本号约定
  • 约定规范
    • <主版本><次版本><增量版本><里程碑版本>
  • 范例:
    • 5.1.9.RELEASE
资源配置
配置文件引用pom属性
  • 作用

    • 在任意配置文件中加载pom文件中定义的属性
  • 调用格式

    1
    ${jdbc.url}
  • 开启配置文件加载pom属性

    1
    2
    3
    4
    5
    6
    7
    8
    9
    <!--配置资源文件对应的信息 -->
    <resources>
    <resource>
    <!--设定配置文件对应的位置目录,支持使用属性动态设定路径-->
    <directory>${project.basedir}/src/main/resouces</directory>
    <!--开启对配置文件的资源加载过滤-->
    <filtering>true</filtering>
    </resource>
    </resources>
多环境开发配置
多环境配置
加载指定环境
跳过测试
应用场景
  • 整体模块功能未开发
  • 模块中某个功能未开发完毕
  • 单个功能更新调试导致其他功能失败
  • 快速打包
  • ……
跳过测试三种方式
  • 使用命令跳过测试
  • 使用界面操作跳过测试
  • 使用配置跳过测试
私服
Nexus

Nexus时Sonatype公司的一款maven私服产品

仓库分类
  • 宿主仓库hosted
    • 保存无法从中央仓库获取的资源
      • 自主研发
      • 第三方非开源项目
  • 代理仓库proxy
    • 代理远程仓库,通过nexus访问其他公共仓库,例如中央仓库
  • 仓库组group
    • 将若干个仓库组成一个群组,简化配置
    • 仓库组不能保存资源,属于设计型仓库
资源上传
  • 上传资源时提供对应的信息
    • 保存的位置(宿主仓库)
    • 资源文件
    • 对应坐标
访问私服配置
  • 本地仓库访问私服

    • 配置本地仓库访问私服的权限(setting.xml)
    • 配置本地仓库资源来源(setting.xml)
  • 项目工程访问私服

    • 配置当前项目访问私服上传资源的保存位置(pom.xml)

    • 发布资源到私服命令

      1
      mvn deploy

参考

学习资料

Maven:【序员Maven全套教程,maven项目管理从基础到高级,Java项目开发必会管理工具maven】

------------- THE END! THANKS! -------------