美文网首页
Maven简单介绍

Maven简单介绍

作者: abboo | 来源:发表于2020-10-09 14:46 被阅读0次

    1.Maven介绍

    1.1 什么是Maven

    Maven 的正确发音是[ˈmevən]。Maven 在美国是一个口语化的词语,代表专家、内行的意思。
    一个对 Maven 比较正式的定义是这么说的:Maven 是一个项目管理工具,它包含了一个项目对象模型 (POM:Project Object Model),一组标准集合,一个项目生命周期(Project Lifecycle),一个依赖管理系统(Dependency Management System),和用来运行定义在生命周期阶段(phase)中插件(plugin)目标
    (goal)的逻辑。

    1.2 Maven能解决什么问题

    可以用更通俗的方式来说明。我们知道,项目开发不仅仅是写写代码而已,期间会伴随着各种必不可少的事情要做,下面列举几个感受一下:

    1、我们需要引用各种 jar 包,尤其是比较大的工程,引用的 jar 包往往有几十个乃至上百个, 每用到一种 jar 包,都需要手动引入工程目录,而且经常遇到各种让人抓狂的 jar 包冲突,版本冲突。

    2、我们辛辛苦苦写好了 Java 文件,可是只懂 0 和 1 的白痴电脑却完全读不懂,需要将它编译成二进制字节码。好歹现在这项工作可以由各种集成开发工具帮我们完成,Eclipse、IDEA 等都可以将代码即时编译。当然,如果你嫌生命漫长,何不铺张,也可以用记事本来敲代码,然后用 javac 命令一
    个个地去编译,逗电脑玩。

    3、世界上没有不存在 bug 的代码,计算机喜欢 bug 就和人们总是喜欢美女帅哥一样。为了追求美为了减少 bug,因此写完了代码,我们还要写一些单元测试,然后一个个的运行来检验代码质量。

    4、再优雅的代码也是要出来卖的。我们后面还需要把代码与各种配置文件、资源整合到一起,定型打包,如果是 web 项目,还需要将之发布到服务器,供人使用。

    试想,如果现在有一种工具,可以把你从上面的繁琐工作中解放出来,能帮你构建工程,管理 jar包,编译代码,还能帮你自动运行单元测试,打包,生成报表,甚至能帮你部署项目,生成 Web 站点,你会心动吗?Maven 就可以解决上面所提到的这些问题。

    1.3 Maven 的优势举例

    前面我们通过 Web 阶段项目,要能够将项目运行起来,就必须将该项目所依赖的一些 jar 包添加到工程中,否则项目就不能运行。试想如果具有相同架构的项目有十个,那么我们就需要将这一份 jar包复制到十个不同的工程中。

    传统工程项目中可能20个java文件打包后的项目大小就可能20M,原因主要是因为我们的 WEB 程序要运行,我们必须将项目运行所需的 Jar 包复制到工程目录中,从
    而导致了工程很大。
    同样的项目,如果我们使用 Maven 工程来构建,会发现总体上工程的大小会少很多。可能只有200k。原因在于maven构建的项目中没有jar包。为什么呢?

    Maven的依赖管理

    Maven 的一个核心特性就是依赖管理。当我们涉及到多模块的项目(包含成百个模块或者子项目),管理依赖就变成一项困难的任务。Maven 展示出了它对处理这种情形的高度控制。

    传统的 WEB 项目中,我们必须将工程所依赖的 jar 包复制到工程中,导致了工程的变得很大。那么

    maven 工程是如何使得工程变得很少呢?
    分析如下:


    通过分析发现:maven 工程中不直接将 jar 包导入到工程中,而是通过在 pom.xml 文件中添加所需 jar包的坐标,这样就很好的避免了 jar 直接引入进来,在需要用到 jar 包的时候,只要查找 pom.xml 文件,再通过 pom.xml 文件中的坐标,到一个专门用于”存放 jar 包的仓库”(maven 仓库)中根据坐标从
    而找到这些 jar 包,再把这些 jar 包拿去运行。

    2.Maven安装及配置

    参考https://blog.csdn.net/winstonlau/article/details/95605557

    3.Maven仓库

    3.1 仓库分类

    maven 的工作需要从仓库下载一些 jar 包,如下图所示,本地的项目 A、项目 B 等都会通过 maven软件从远程仓库(可以理解为互联网上的仓库)下载 jar 包并存在本地仓库,本地仓库 就是本地文件夹,当第二次需要此 jar 包时则不再从远程仓库下载,因为本地仓库已经存在了,可以将本地仓库理解为缓存,有了本地仓库就不用每次从远程仓库下载了。

    • 本地仓库 :用来存储从远程仓库或中央仓库下载的插件和 jar 包,项目使用一些插件或 jar 包,优先从本地仓库查找。

    默认本地仓库位置在 ${user.dir}/.m2/repository${user.dir}表示 windows 用户目录

    • 远程仓库:如果本地需要插件或者 jar 包,本地仓库没有,默认去远程仓库下载。
      远程仓库可以在互联网内也可以在局域网内。
    • 中央仓库 :在 maven 软件中内置一个远程仓库地址 http://repo1.maven.org/maven2 ,它是中央仓库,服务于整个互联网,它是由 Maven 团队自己维护,里面存储了非常全的 jar 包,它包含了世界上大部分流行的开源项目构件。

    3.1.2全局settings和用户settings

    maven 仓库地址、私服等配置信息需要在 setting.xml 文件中配置,分为全局配置和用户配置。

    • 在 maven 安装目录下的有 conf/setting.xml 文件,此 setting.xml 文件用于 maven 的所有 project项目,它作为 maven 的全局配置。
    • 如需要个性配置则需要在用户配置中设置,用户配置的 setting.xml 文件默认的位置在:${user.home} /.m2/settings.xml目录中,${user.home}指 mac下用户目录。

    maven 会先找用户配置,如果找到则以用户配置文件为准,否则使用全局配置文件。

    4. Maven 工程的认识

    4.1 Maven项目结构

    项目结构

    src/main/java —— 存放项目的.java 文件
    src/main/resources —— 存放项目资源文件,如 spring, hibernate 配置文件
    src/test/java —— 存放所有单元测试.java 文件,如 JUnit 测试类
    src/test/resources —— 测试资源文件
    target —— 项目输出位置,编译后的 class 文件会输出到此目录
    pom.xml——maven 项目核心配置文件,如坐标的信息
    注意:如果是普通的 java 项目,那么就没有 webapp 目录。

    4.2 Maven 工程的运行

    进入 maven 工程目录(当前目录有 pom.xml 文件),运行 tomcat:run 命令。

    4.3 Maven常用命令

    格式mvn {命令}

    • clean 清除项目编译信息,执行 clean 会删除 target 目录及内容。
    • compile compile 是 maven 工程的编译命令,作用是将 src/main/java 下的文件编译为 class 文件输出到 target目录下。
    • test test 是 maven 工程的测试命令 mvn test,会执行 src/test/java 下的单元测试类。同时也对src/main/java下的代码编译了,也就是说执行test命令,compile命令也执行了一次。
    • pacakge 打包命令,对于 java 工程执行 package 打成 jar 包,对于 web 工程打成 war包。对compile 和 test 也都执行了一次
    • install 安装命令,执行 install 将 maven 打成 jar 包或 war 包发布到本地仓库。前面三个命令也都执行了一次
    • deploy 打包项目到私服,前面四个执行了一次
      可以看出:当后面的命令执行时,前面的操作过程也都会自动执行。


      Maven生命周期

    4.4 maven 的概念模型

    Maven 包含了一个项目对象模型 (Project Object Model),一组标准集合,一个项目生命周期(Project Lifecycle),一个依赖管理系统(Dependency Management System),和用来运行定义在生命周期阶段(phase)中插件(plugin)目标(goal)的逻辑。


    概念模型
    • 项目对象模型 (Project Object Model)
      一个 maven 工程都有一个 pom.xml 文件,通过 pom.xml 文件定义项目的坐标、项目依赖、项目信息、插件目标等。
    • 依赖管理系统(Dependency Management System)
      通过 maven 的依赖管理对项目所依赖的 jar 包进行统一管理。
      比如:项目依赖 junit4.9,通过在 pom.xml 中定义 junit4.9 的依赖即使用 junit4.9,如下所示是 junit4.9的依赖定义:
    <!-- 依赖关系 -->
        <dependencies>
        <!-- 此项目运行使用 junit,所以此项目依赖 junit -->
        <dependency>
            <!-- junit 的项目名称 -->
            <groupId>junit</groupId>
            <!-- junit 的模块名称 -->
            <artifactId>junit</artifactId>
            <!-- junit 版本 -->
            <version>4.9</version>
            <!-- 依赖范围:单元测试时使用 junit -->
            <scope>test</scope>
        </dependency>
    
    • 一个项目生命周期(Project Lifecycle)
      使用 maven 完成项目的构建,项目构建包括:清理、编译、测试、部署等过程,maven 将这些
      过程规范为一个生命周期,如下所示是生命周期的各各阶段:



      maven 通过执行一些简单命令即可实现上边生命周期的各各过程,比如执行 mvn compile 执行编译、执行 mvn clean 执行清理。

    • 一组标准集合
      maven 将整个项目管理过程定义一组标准,比如:通过 maven 构建工程有标准的目录结构,有标准的生命周期阶段、依赖管理有标准的坐标定义等。
    • 插件(plugin)目标(goal)
      maven 管理项目生命周期过程都是基于插件完成的。

    4.5 依赖范围

    <score></score>
    A 依赖 B,需要在 A 的 pom.xml 文件中添加 B 的坐标,添加坐标时需要指定依赖范围,依赖范围包
    括:

    • compile:编译范围,指 A 在编译时依赖 B,此范围为默认依赖范围。编译范围的依赖会用在编译、测试、运行,由于运行时需要所以编译范围的依赖会被打包。
    • provided:provided 依赖只有在当 JDK 或者一个容器已提供该依赖之后才使用, provided 依 赖在编译和测试时需要,在运行时不需要,比如:servlet api 被 tomcat 容器提供。
    • runtime:runtime 依赖在运行和测试系统的时候需要,但在编译的时候不需要。比如:jdbc的驱动包。由于运行时需要所以 runtime 范围的依赖会被打包。
    • test:test 范围依赖 在编译和运行时都不需要,它们只有在测试编译和测试运行阶段可用,
      比如:junit。由于运行时不需要所以 test范围依赖不会被打包。
    • system:system 范围依赖与 provided 类似,但是你必须显式的提供一个对于本地系统中 JAR文件的路径,需要指定 systemPath 磁盘路径,system依赖不推荐使用。


    在 maven-web 工程中测试各各 scop。
    测试总结:

    • 默认引入 的 jar 包 ------- compile 【默认范围 可以不写】(编译、测试、运行 都有效 )
    • servlet-api 、jsp-api ------- provided (编译、测试 有效, 运行时无效 防止和 tomcat 下 jar 冲突)
    • jdbc 驱动 jar 包 ---- runtime (测试、运行 有效 )
    • junit ----- test (测试有效)

    依赖范围由强到弱的顺序是:compile>provided>runtime>test

    相关文章

      网友评论

          本文标题:Maven简单介绍

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