Maven详见及在Idea中的使用方法[保姆级包学包会]

文章目录

  • Maven详解
    • 1.1 目标
    • 1.2 Maven概括
    • 1.3 多模块开发
      • 1.3.1 pom.xml
      • 1.3.2 生命周期
      • 1.3.3 依赖特性(多模块1)
      • 1.3.4 继承特性(多模块2)
      • 1.3.5 dependencyManagement标签
      • 1.3.6 Maven-聚合(多模块3)
        • 聚合 1.3.6.1
        • 聚合总结

Maven详解

1.1 目标

  • maven是什么?
  • maven能干什么?
  • maven是如何工作的?
  • maven中你遇到过什么问题,是通过什么方法,手段定位的问题,然后如何解决的?

1.2 Maven概括

  • maven简介

  • Maven 是一个项目管理和综合工具。Maven 提供了开发人员构建一个完整的生命周期框架。开发团队可以自动完成项目的基础工具建设,Maven 使用标准的目录结构和默认构建生命周期。

  • 在多个开发团队环境时,Maven 可以设置按标准在非常短的时间里完成配置工作。由于大部分项目的设置都很简单,并且可重复使用,Maven 让开发人员的工作更轻松,同时创建报表,检查,构建和测试自动化设置。

  • 概括地说,Maven 简化和标准化项目建设过程。处理编译,分配,文档,团队协作和其他任务的无缝连接。 Maven 增加可重用性并负责建立相关的任务。有了maven你的工作就简单了.

  • 下载安装(略)

      idea自带一套maven的环境.使用idea开发,无需安装windows的maven.
    
      但是有的开发者,喜欢单独使用maven,windows单独安装了一套.
    

1.3 多模块开发

1.3.1 pom.xml

  • 每一个maven项目都有一个pom文件.Project Object Model 项目对象模型,maven作为一个项目开发管理工具,将每一个项目看成是一个对象.pom文件是描述这个对象的数据文件**(元数据)**.通过pom文件的内容,maven软件就可以管理控制项目.

1.3.2 生命周期

maven管理项目时,总是先加载pom然后执行声明周期的命令逻辑,maven项目从创建开始,要经历如下几个生命周期环节.

概念: 生命周期,对象目标经历的环节,经历的步骤.
Maven详见及在Idea中的使用方法[保姆级包学包会]_第1张图片

  • validate:
    底层执行的maven命令 实际上 .校验一下 当前没问结构,环境是否符合maven项目开发要求.
    idea中几乎不会用到.
    mvn validate

  • compile:
    maven项目的编译,只负责main中相关内容的编译输出,默认输出到 target/classes
    mvn compile

  • test
    执行项目的单元测试. 会生成单元测试报告,包含前一步的compile,并且将测试代码编译输出
    mvn test

  • package
    将项目打包
    注意: 根据packaging类型不一样,打包的输出结果就不同.类型有三种常用的
    jar/war/pom.第三种类型没有代码,只能作为父工程或者聚合工程使用
    mvn package

  • install
    将项目打包,安装存放到本地库(远程库,本地库.目前的远程库 central中央库)
    mvn install

  • site
    根据Maven配置生成一个html页面集.针对这个项目做的可观测页面.
    mvn sit

  • deploy
    和私服有关.公司开发,传递jar包的方式
    mvn deploy
    Idea自定义运行命令
    Maven详见及在Idea中的使用方法[保姆级包学包会]_第2张图片
    执行自定义maven命令,添加一个选项-X可以在控制台打印maven执行命令的详细日志.
    目的是在出错的时候,帮助我们提供更准确的定位信息.
    提问: 所有maven项目的生命周期经历的环节都完全一样么?
    例如:
    项目运行的web应用: compile test package install deploy(不需要)
    项目是提供给同事复用的代码: compile test pakcage install deploy

1.3.3 依赖特性(多模块1)

Maven详见及在Idea中的使用方法[保姆级包学包会]_第3张图片
Maven详见及在Idea中的使用方法[保姆级包学包会]_第4张图片
依赖

  • 作用是什么: 代码项目的复用
  • 如何使用: dependency标签
  • 特性是什么: 依赖有传递性
  • idea中想要观察依赖的传递性: 传递性是强制传递,maven允许提出不需要的传递
<dependencies>
    <dependency>
        <groupId>org.springframeworkgroupId>
        <artifactId>spring-contextartifactId>
        <version>5.2.22.RELEASEversion>
        
        <exclusions>
            <exclusion>
                <groupId>org.springframeworkgroupId>
                <artifactId>spring-aopartifactId>
            exclusion>
            <exclusion>
                <groupId>org.springframeworkgroupId>
                <artifactId>spring-coreartifactId>
            exclusion>
        exclusions>
    dependency>
dependencies>

Maven详见及在Idea中的使用方法[保姆级包学包会]_第5张图片
Maven详见及在Idea中的使用方法[保姆级包学包会]_第6张图片

1.3.4 继承特性(多模块2)

  • 在同一个项目中不同模块的开发者中,各自维护自己的项目依赖关系,有可能出现图中的情况,相互关联的两个模块同时依赖A.jar,但是版本不同,会导致严重的结果,相互之间的关系存在兼容问题. 为了保证没有兼容问题.
  • 继承意义
    为了统一多模块协作多人开发版本资源,maven提供了一个多模块特性–继承
    继承的实现
  • 确定父子关系**(文件夹结构就是父子关系)**
  • 父工程packaging标签值必须是pom,子工程使用parent标签指向父工程(idea自动帮你实现了)
    区分开类的继承,和maven的继承细节.区分开依赖和继承的区别
    细节: parent标签详解
<parent>
    <groupId>org.springframework.bootgroupId>
    <artifactId>spring-boot-starter-parentartifactId>
    <version>2.7.13version>
    <relativePath/> 
parent>

relativePath: 子工程寻找父工程pom文件的相对路径地址.如果子工程无法找到父工程的pom,无法实现继承.这个值有三种配置方式

  1. 默认值(不给标签) …/pom.xml
  2. 自定义值,根据你的pom位置,合理的编写路径信息(夸文件夹级别继承)
  3. 空值 只在本地库找父工程的pom文件,如果本地库没有,从远程库下载
  • 本地库资源路径(必须掌握通过maven标签找到库资源)

    • 找本地库在哪c:/{User}/.m2/repository/org/springframework/boot/spring-boot-starter-parent/2.7.13
  • 继承的本质
    子工程继承父工程, pom文件的继承,继承之后,获取的内容就是pom文件中的标签.
    pom文件中标签的复用 依赖才是代码的复用

  • 常见的继承标签

    • groupId
    • version
    • properties
    • dependencies
    • dependencyManagement

1.3.5 dependencyManagement标签

依赖管理,在依赖管理标签定义的是依赖版本,dependencyManagement包含了一套完整的dependencies.
一旦在项目中定义了依赖管理,再使用依赖的时候,就可以省略版本号了.所以我们在父工程统一规划好所有的依赖资源版本,dependencyManagement被子工程继承之后,拥有了相同的特性,相当于做到了资源版本的统一定义,子工程尽可能不重写版本.

  • 补充
  1. 父工程定义一堆dependencies 能否实现统一管理资源版本? 能.
  2. 为什么不用? 因为这种统一管理版本 是一种强制的继承,让子工程承担了非常多不需要用到的依赖资源
    结合 properties和dependencyManagement的继承特性和标签的功能.父子继承的时候最终父工程样子Maven详见及在Idea中的使用方法[保姆级包学包会]_第7张图片按照上图,修改maven parent demo案例
    观察一些父工程的pom文件,能够阅读其中的pom标签.
    spring-boot-starter-parentMaven详见及在Idea中的使用方法[保姆级包学包会]_第8张图片

1.3.6 Maven-聚合(多模块3)

聚合 1.3.6.1

有依赖,有继承关系,已经看到maven多模块了.
一个团队开发项目时候,一定多模块管理的.多人协作开发,使用maven管理项目关系的.
假如项目结构:
Maven详见及在Idea中的使用方法[保姆级包学包会]_第9张图片a1,a2,b1,b2是项目中4个人共同并行开发的.每个项目都是一个应用的web程序,所以目的都是打成jar包,运行java启动命令

java -jar a1.jar
java -jar a2.jar
java -jar b1.jar
java -jar b2.jar

每个项目都要执行maven声明周期中以下几个命令

  • mvn clean compile 编译
  • mvn clean test 测试
  • mvn clean package 打包
    发现2个问题需要解决:
  1. 打包命令重复执行很多遍.
  2. 执行相同命令时,还需要额外关心项目依赖关系.
  • 聚合的目的,就是为了统一执行mvn相关命令的.而不需要关心,依赖关系,继承关系,聚合本身就保管了所有的多模块关系.

如何实现聚合:

  1. 挑选一个聚合工程,聚合工程packaging类型是pom(和父工程要求是一致的)
  2. 聚合工程来实现modules配置.指向被聚合的工程(idea在创建工程时,自动实现的)
    maven-parent-demo 顶级父工程
<modules>
    <module>a1module>
    <module>a2module>
modules>
  • 如果idea版本不同,在创建项目时,聚合的配置有所区别,有可能在顶级父工程中,聚合了所有人
  • 配置完上述两部操作,只需要对聚合工程执行mvn命令,统一对被聚合工程执行相同的命令,而且满足依赖关系
    Maven详见及在Idea中的使用方法[保姆级包学包会]_第10张图片

聚合总结

  • 意义: 统一多模块mvn命令和顺序的执行
  • 实现: 聚合工程packaging类型pom ,指向module被聚合工程
  • 本质: pom文件加载的顺序,通过modules关联起来了.

你可能感兴趣的:(Maven相关,maven,intellij-idea,java,ide)