简介

Maven是什么

  • Maven 的本质是一个项目管理工具,将项目开发和管理过程抽象成一个项目对象模型(POM)
  • POM(ProjectObject Model):项目对象模型

Maven的作用

  • 项目构建:提供标准的、跨平台的自动化项目构建方式
  • 依赖管理:方便快捷的管理项目依赖的资源(jar包),避免资源间的版本冲突问题
  • 统一开发结构:提供标准的、统一的项目结构

Maven基础概念

仓库(本地、私服、中央)

  • 仓库:用于存储资源,包含各种jar包
    • 仓库分类:
    • 本地仓库:自己电脑上存储资源的仓库,连接远程仓库获取资源;
    • 远程仓库:非本机电脑上的仓库,为本地仓库提供资源
      • 中央仓库:Maven团队维护,存储所有资源的仓库
      • 私服:部门/公司范围内存储资源的仓库,从中央仓库获取资源
  • 私服的作用:
    • 保存具有版权的资源,包含购买或自主研发的jar;中央仓库中的iar都是开源的,不能存储具有版权的资源
    • 一定范围内共享资源,仅对内部开放,不对外共享

坐标

  • 什么是坐标?
    • Maven中的坐标用于描述仓库中资源的位置
  • 坐标主要组成
    • groupld:定义当前Maven项目隶属组织名称(通常是域名反写,例如:org.mybatis)
    • artifactld:定义当前Maven项目名称(通常是模块名称,例如CRM、SMS)
    • version:定义当前项目版本号
    • packaging:定义该项目的打包方式

Maven Repository: Search/Browse/Explore (mvnrepository.com)

仓库设置

Maven项目

Maven项目搭建

  • 手工
  • IDEA生成

Maven项目构建(也可在IDEA里实现)

1
2
3
4
5
mvn compile      #编译
mvn clean #清理
mvn test #测试
mvn package #打包
mvn install #安装到本地仓库

打包方式:web工程打包为war,java工程打包为jar

Maven插件创建工程

1
2
3
4
5
6
7
8
9
10
#创建工程
mvn archetype:generate
-DgroupId={project-packaging}
-DartifactId={project-name}
-DarchetypeArtifactId=maven-archetype-quickstart
-DinteractiveMode=false
#创建java工程
mvn archetype:generate -DgroupId=com.qianqianzyk -DartifactId=java-project -DarchetypeArtifactId=maven-archetype-quickstart -Dversion=0.0.1-snapshot -DinteractiveMode=false
#创建web工程
mvn archetype:generate -DgroupId=com.qianqianzyk -DartifactId=web-project -DarchetypeArtifactId=maven-archetype-webapp -Dversion=0.0.1-snapshot -DinteractiveMode=false

添加tomcat插件(web工程)

1
2
3
4
5
6
7
8
9
10
11
12
13
<build>
<plugins>
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.1</version>
<configuration>
<port>80</port>
<path>/</path>
</configuration>
</plugin>
</plugins>
</build>

依赖配置与依赖传递

1
2
3
4
5
6
7
<dependencies>
<dependency>
<groupId></groupId>
<artifactId></artifactId>
<version></version>
</dependency>
</dependencies>
  • 依赖具有传递性

    • 直接依赖:在当前项目中通过依赖配置建立的依赖关系
    • 间接依赖:被资源的资源如果依赖其他资源,当前项目间接依赖其他资源
  • 依赖传递冲突问题

    • 路径优先:当依赖中出现相同的资源时,层级越深,优先级越低,层级越浅,优先级越高
    • 声明优先:当资源在相同层级被依赖时,配置顺序靠前的覆盖配置顺序靠后的
    • 特殊优先:当同级配置了相同资源的不同版本,后配置的覆盖先配置的
  • 可选依赖(对外隐藏当前所依赖的资源 - 不透明)

    在依赖配置最后一行加一个<optional>true</optional>

  • 排除依赖(主动断开依赖的资源 - 不需要)

    1
    2
    3
    4
    5
    6
    <exclusions>
    <exclusion>
    <groupId></groupId>
    <artifactId></artifactId>
    </exclusion>
    </exclusions>
  • 依赖范围

    • 依赖的iar默认情况可以在任何地方使用,可以通过scope标签设定其作用范围
    • 作用范围
      • 主程序范围有效(main文件夹范围内)
      • 测试程序范围有效(test文件夹范围内)
      • 是否参与打包(package指令范围内)

  • 依赖范围传递性

生命周期与插件

项目构建生命周期

  • 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>
<groupId>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>

分模块开发

  • 模块中仅包含当前模块对应的功能类与配置文件
  • spring核心配置根据模块功能不同进行独立制作
  • 当前模块所依赖的模块通过导入坐标的形式加入当前模块后才可以使用
  • web.xml需要加载所有的spring核心配置文件

模块聚合

新建一个module用来管理多模块

父工程的pom.xml

1
2
3
4
5
6
7
8
9
<packaging>pom</packaging>

<modules>
<!--具体的工程名称-->
<module>../ssm_pojo</module>
<module>../ssm_dao</module>
<module>../ssm_service</module>
<module>../ssm_controller</module>
</modules>

模块继承

父工程的pom.xml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<dependencyManagement>
<!--具体的依赖-->
<dependencies>
<dependency></dependency>
<dependency></dependency>
</dependencies>
</dependencyManagement>

<build>
<pluginManagement>
<plugins>
<plugin></plugin>
<plugin></plugin>
</plugins>
</pluginManagement>
</build>

子工程的pom.xml

1
2
3
4
5
6
7
8
9
<!--定义该工程的父工程-->
<parent>
<groupId></groupId>
<artifactId>ssm</artifactId>
<version></version>
<relativePath>../ssm/pom.xml</relativePath>
</parent>

<!--子工程的各依赖的version可以删除,即使用父工程的version-->

继承与聚合

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

属性

相当于配置了一个变量名

1
2
3
4
5
6
7
<!--定义自定义属性-->
<properties>
<spring.version>5.1.9.RELEASE</spring.version>
</properties>

<!--调用-->
<version>${spring.version}</version>

内置属性

1
2
${basedir}
${version}

Setting属性

使用Maven配置文件setting.xml中的标签属性,用于动态配置

1
${settings.localRepository}

系统属性查询方式

1
mvn help:system

版本管理

工程版本

  • SNAPSHOT(快照版本)
    • 项目开发过程中,为方便团队成员合作,解决模块间相互依赖和时时更新的问题,开发者对每个模块进行构建的时候,输出的临时性版本叫快照版本(测试阶段版本)
    • 快照版本会随着开发的进展不断更新
  • RELEASE(发布版本)
    • 项目开发到进入阶段里程碑后,向团队外部发布较为稳定的版本,这种版本所对应的构件文件是稳定的,即便进行功能的后续开发,也不会改变当前发布版本内容,这种版本称为发布版本

工程版本号约定

  • 约定规范:
    • <主版本>.<次版本>.<增量版本>.<里程碑版本>
    • 主版本:表示项目重大架构的变更,如:spring5相较于spring4的选代
    • 次版本:表示有较大的功能增加和变化,或者全面系统地修复漏洞
    • 增量版本:表示有重大漏洞的修复
    • 里程碑版本:表明一个版本的里程碑!(版本内部)。这样的版本同下一个正式版本相比,相对来说不是很稳定,有待更多的测试
  • 范例:
    • 5.1.9.RELEASE

资源配置

父工程的pom.xml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<properties>
<jdbc.url>jdbc:mysql://127.0.0.1:3306/ssm_db</jdbc.url>
</properties>

<build>
<resources>
<resource>
<directory>${project.basedir}/src/main/resources</directory>
<filtering>true</filtering>
</resource>
</resources>

<testResources>
<resource>
<directory>${project.basedir}/src/test/resources</directory>
<filtering>true</filtering>
</resource>
</testResources>
</build>

多环境配置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<profiles>
<!--生产环境-->
<profile>
<id>pro_env</id>
<properties>
<jdbc.url>jdbc:mysql://127.0.0.1:3306/ssm_db</jdbc.url>
</properties>
<!--设置默认环境-->
<activation>
<activeByDefault>true</activeByDefault>
</activation>
</profile>
<!--开发环境-->
<profile>
<id>dep_env</id>
<properties>
<jdbc.url>jdbc:mysql://127.0.0.1:3306/ssm_db</jdbc.url>
</properties>
</profile>
</profiles>
1
mvn 指令 -P 环境定义id

跳过测试

跳过测试环节的应用场景

  • 整体模块功能未开发
  • 模块中某个功能未开发完毕
  • 单个功能更新调试导致其他功能失败
  • 快速打包
  • ······
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<pluginManagement>
<plugins>
<plugin>
<groupId></groupId>
<artifactId></artifactId>
<version></version>
<configuration>
<!--跳过-->
<skipTests>true</skipTests>
<!--包含指定的用例-->
<includes>
<include>**/UserServiceTest.java</include>
</includes>
<excludes>
<exclude></exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</pluginManagement>
1
mvn install -D skipTests

私服

Nexus

Download (sonatype.com)

1
nexus.exe /run nexus
1
http://localhost:8081

私服资源获取

仓库分类

  • 宿主仓库hosted
    • 保存无法从中央仓库获取的资源
      • 自主研发
      • 第三方非开源项目
  • 代理仓库proxy
    • 代理远程仓库,通过nexus访问其他公共仓库,例如中央仓库
  • 仓库组group
    • 将若干个仓库组成一个群组,简化配置
    • 仓库组不能保存资源,属于设计型仓库

idea中资源上传与下载

本地仓库settings.xml配置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<mirrors>
<mirror>
<id>nexus-qianqianzyk</id>
<url>http://localhost:8081/repository/maven-public/</url>
<mirrorOf>*</mirrorOf>
</mirror>
</mirrors>

<servers>
<server>
<id>qianqianzyk-release</id>
<username>admin</username>
<password></password>
</server>
<server>
<id>qianqianzyk-snapshots</id>
<username>admin</username>
<password></password>
</server>
<servers>

发布配置管理pom.xml

1
2
3
4
5
6
7
8
9
10
<distributionManagement>
<repository>
<id>qianqianzyk-release</id>
<url>http://localhost:8081/repository/qianqianzyk-release/</url>
</repository>
<snapshotRepository>
<id>qianqianzyk-snapshots</id>
<url>http://localhost:8081/repository/qianqianzyk-snapshots/</url>
</snapshotRepository>
</distributionManagement>
1
mvn deploy