美文网首页
maven总结

maven总结

作者: WAHAHA402 | 来源:发表于2021-07-23 16:37 被阅读0次

    maven教程

    1、maven是什么?

    maven是一个项目管理工具,可以对java项目进行构建、依赖管理。是 Apache 下的一个纯 Java 开发的开源项目。也可被用来构建和管理各种项目,如C#,Ruby,Scala 和其他语言编写的项目。它是基于项目对象模型(缩写:POM)概念,管理一个项目的构建、报告和文档等步骤。

    2、maven pom

    POM( Project Object Model,项目对象模型 ) 是 Maven 工程的基本工作单元,是一个XML文件,包含了项目的基本信息,用于描述项目如何构建,声明项目依赖,等等。maven读取pom获取信息,来执行目标。

    POM 中可以指定以下配置:

    • 项目依赖
    • 插件
    • 执行目标
    • 项目构建 profile
    • 项目版本
    • 项目开发者列表
    • 相关邮件列表信息
    2.1、父pom

    父(Super)POM是 Maven 默认的 POM。所有的 POM 都继承自一个父 POM(无论是否显式定义了这个父 POM)。父 POM 包含了一些可以被继承的 默认设置。因此,当 Maven 发现需要下载 POM 中的 依赖时,它会到 Super POM 中配置的默认仓库 http://repo1.maven.org/maven2 去下载。

    Maven 使用 effective pom(Super pom 加上工程自己的配置)来执行相关的目标,它帮助开发者在 pom.xml 中做尽可能少的配置,当然这些配置可以被重写。

    使用以下命令来mvn help:effective-pom会在控制台看到父pom的默认配置。

    在父 pom.xml 中,你可以看到 Maven 在执行目标时需要用到的工程源码目录结构、输出目录、需要的插件、仓库和报表目录

    pom中可使用的标签大全可以在这个网页看到https://www.runoob.com/maven/maven-pom.html,当然建议看官网最好。

    3、maven构建生命周期

    Maven 构建生命周期定义了一个项目构建跟发布的过程。Maven 有以下三个标准的生命周期:

    • clean:项目清理的处理
    • default(或 build):项目部署的处理
    • site:项目站点文档创建的处理

    default(或 build)生命周期是开发过程中最主要最常接触到的,它由以下几个阶段(phase)的序列组成:


    default(或 build)生命周期包含的阶段(phase)

    说得通透一点,maven构建过程可以理解成,由各种plugin按照部分或全部的生命周期的阶段(phase)顺序执行阶段绑定的goal(底层是插件中的java方法)来完成java项目清理、编译、打包、测试、布署等整个项目的流程的一个过程。在一个生命周期中,运行某个阶段的时候,它之前的所有阶段都会被运行。

    生命周期(lifecycle)由各个阶段组成,每个阶段由maven的插件plugin来执行goal完成。

    3.1 构建阶段(phase)由插件目标(goal)构成

    一个插件目标代表一个特定的任务(比构建阶段更为精细),这有助于项目的构建和管理。这些目标可能被绑定到多个阶段或者无绑定。不绑定到任何构建阶段的目标可以在构建生命周期之外通过直接调用执行。这些目标的执行顺序取决于调用目标和构建阶段的顺序。

    例如,考虑下面的命令:
    mvn clean dependency:copy-dependencies package

    clean 和 pakage 是构建阶段,dependency:copy-dependencies 是目标。这里的 clean 阶段将会被首先执行,然后 dependency:copy-dependencies 目标会被执行,最终 package 阶段被执行。

    4、maven构建配置文件

    构建配置文件是一系列的配置项的值,可以用来设置或者覆盖 Maven 构建默认值。

    使用构建配置文件,你可以为不同的环境,比如说生产环境(Production)和开发(Development)环境,定制构建方式。

    配置文件在 pom.xml 文件中使用 activeProfiles 或者 profiles 元素指定,并且可以通过各种方式触发。配置文件在构建时修改 POM,并且用来给参数设定不同的目标环境(比如说,开发(Development)、测试(Testing)和生产环境(Production)中数据库服务器的地址)。

    配置文件级别和激活方式
    4.1 命令行配置文件激活

    profile 可以让我们定义一系列的配置信息,然后指定其激活条件。这样我们就可以定义多个 profile,然后每个 profile 对应不同的激活条件和配置信息,从而达到不同环境使用不同配置信息的效果。

    以下实例,我们将 maven-antrun-plugin:run 目标添加到测试阶段中。这样我们可以在不同的 profile 中输出文本信息。我们将使用 pom.xml 来定义不同的 profile,并在命令控制台中使用 maven 命令激活 profile。

    pom.xml 文件如下:

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
      xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
      <modelVersion>4.0.0</modelVersion>
      <groupId>com.jsoft.test</groupId>
      <artifactId>testproject</artifactId>
      <packaging>jar</packaging>
      <version>0.1-SNAPSHOT</version>
      <name>testproject</name>
      <url>http://maven.apache.org</url>
      <dependencies>
        <dependency>
          <groupId>junit</groupId>
          <artifactId>junit</artifactId>
          <version>3.8.1</version>
          <scope>test</scope>
        </dependency>
      </dependencies>
      <profiles>
          <profile>
              <id>test</id>
              <build>
                  <plugins>
                     <plugin>
                        <groupId>org.apache.maven.plugins</groupId>
                        <artifactId>maven-antrun-plugin</artifactId>
                        <version>1.8</version>
                        <executions>
                           <execution>
                              <phase>test</phase>
                              <goals>
                                 <goal>run</goal>
                              </goals>
                              <configuration>
                              <tasks>
                                 <echo>Using env.test.properties</echo>
                                 <copy file="src/main/resources/env.test.properties" tofile="${project.build.outputDirectory}/env.properties" overwrite="true"/>
                              </tasks>
                              </configuration>
                           </execution>
                        </executions>
                     </plugin>
                  </plugins>
              </build>
          </profile>
          <profile>
              <id>normal</id>
              <build>
                  <plugins>
                     <plugin>
                        <groupId>org.apache.maven.plugins</groupId>
                        <artifactId>maven-antrun-plugin</artifactId>
                        <version>1.8</version>
                        <executions>
                           <execution>
                              <phase>test</phase>
                              <goals>
                                 <goal>run</goal>
                              </goals>
                              <configuration>
                              <tasks>
                                 <echo>Using env.properties</echo>
                                 <copy file="src/main/resources/env.properties" tofile="${project.build.outputDirectory}/env.properties" overwrite="true"/>
                              </tasks>
                              </configuration>
                           </execution>
                        </executions>
                     </plugin>
                  </plugins>
              </build>
          </profile>
          <profile>
              <id>prod</id>
              <build>
                  <plugins>
                     <plugin>
                        <groupId>org.apache.maven.plugins</groupId>
                        <artifactId>maven-antrun-plugin</artifactId>
                        <version>1.8</version>
                        <executions>
                           <execution>
                              <phase>test</phase>
                              <goals>
                                 <goal>run</goal>
                              </goals>
                              <configuration>
                              <tasks>
                                 <echo>Using env.prod.properties</echo>
                                 <copy file="src/main/resources/env.prod.properties" tofile="${project.build.outputDirectory}/env.properties" overwrite="true"/>
                              </tasks>
                              </configuration>
                           </execution>
                        </executions>
                     </plugin>
                  </plugins>
              </build>
          </profile>
       </profiles>
    </project>
    

    注意:构建配置文件采用的是 <profiles> 节点。

    说明:上面新建了三个 <profiles>,其中 <id> 区分了不同的 <profiles> 执行不同的 AntRun 任务;而 AntRun 的任务可以这么理解,AntRun 监听 test 的 Maven 生命周期阶段,当 Maven 执行 test 时,就触发了 AntRun 的任务,任务里面为输出文本并复制文件到指定的位置;而至于要执行哪个 AntRun 任务,此时构建配置文件起到了传输指定的作用,比如,通过命令行参数输入指定的 <id>。

    执行命令:mvn test -Ptest
    提示:第一个 test 为 Maven 生命周期阶段,第 2 个 test 为构建配置文件指定的 <id> 参数,这个参数通过 -P 来传输,当然,它可以是 prod 或者 normal 。

    4.2、通过Maven设置激活配置文件
    <settings xmlns="http://maven.apache.org/POM/4.0.0"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
       http://maven.apache.org/xsd/settings-1.0.0.xsd">
       ...
       <activeProfiles>
          <activeProfile>test</activeProfile>
       </activeProfiles>
    </settings>
    
    4.3 通过环境变量激活配置文件

    先把上一步测试的 setting.xml 值全部去掉。

    然后在 pom.xml 里面的 <id> 为 test 的 <profile> 节点,加入 <activation> 节点:

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
     <modelVersion>4.0.0</modelVersion>
     <groupId>com.jsoft.test</groupId>
     <artifactId>testproject</artifactId>
     <packaging>jar</packaging>
     <version>0.1-SNAPSHOT</version>
     <name>testproject</name>
     <url>http://maven.apache.org</url>
     <dependencies>
       <dependency>
         <groupId>junit</groupId>
         <artifactId>junit</artifactId>
         <version>3.8.1</version>
         <scope>test</scope>
       </dependency>
     </dependencies>
     <profiles>
         <profile>
             <id>test</id>
             <activation>
               <property>
                  <name>env</name>
                  <value>test</value>
               </property>
             </activation>
             <build>
                 <plugins>
                    <plugin>
                       <groupId>org.apache.maven.plugins</groupId>
                       <artifactId>maven-antrun-plugin</artifactId>
                       <version>1.8</version>
                       <executions>
                          <execution>
                             <phase>test</phase>
                             <goals>
                                <goal>run</goal>
                             </goals>
                             <configuration>
                             <tasks>
                                <echo>Using env.test.properties</echo>
                                <copy file="src/main/resources/env.test.properties" tofile="${project.build.outputDirectory}/env.properties" overwrite="true"/>
                             </tasks>
                             </configuration>
                          </execution>
                       </executions>
                    </plugin>
                 </plugins>
             </build>
         </profile>
         
         <profile>
             <id>prod</id>
             <build>
                 <plugins>
                    <plugin>
                       <groupId>org.apache.maven.plugins</groupId>
                       <artifactId>maven-antrun-plugin</artifactId>
                       <version>1.8</version>
                       <executions>
                          <execution>
                             <phase>test</phase>
                             <goals>
                                <goal>run</goal>
                             </goals>
                             <configuration>
                             <tasks>
                                <echo>Using env.prod.properties</echo>
                                <copy file="src/main/resources/env.prod.properties" tofile="${project.build.outputDirectory}/env.properties" overwrite="true"/>
                             </tasks>
                             </configuration>
                          </execution>
                       </executions>
                    </plugin>
                 </plugins>
             </build>
         </profile>
      </profiles>
    </project>
    
    

    或执行命令mvn test -Denv=test

    上面使用 -D 传递环境变量,其中 env 对应刚才设置的 <name> 值,test 对应<value>。

    5、maven仓库

    Maven 仓库能帮助我们管理构件(主要是JAR),它就是放置所有JAR文件(WAR,ZIP,POM等等)的地方。

    Maven 仓库有三种类型:
    本地(local)
    中央(central)
    远程(remote)

    5.1 本地仓库

    Maven 的本地仓库,在安装 Maven 后并不会创建,它是在第一次执行 maven 命令的时候才被创建。
    运行 Maven 的时候,Maven 所需要的任何构件都是直接从本地仓库获取的。如果本地仓库没有,它会首先尝试从远程仓库下载构件至本地仓库,然后再使用本地仓库的构件。
    默认情况下,,每个用户在自己的用户目录下都有一个路径名为 .m2/respository/ 的仓库目录。
    Maven 本地仓库默认被创建在 %USER_HOME% 目录下。要修改默认位置,在 %M2_HOME%\conf 目录中的 Maven 的 settings.xml 文件中定义另一个路径。

    <settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 
       http://maven.apache.org/xsd/settings-1.0.0.xsd">
          <localRepository>C:/MyLocalRepository</localRepository>
    </settings>
    
    5.2 中央仓库

    Maven 中央仓库是由 Maven 社区提供的仓库,其中包含了大量常用的库。

    中央仓库包含了绝大多数流行的开源Java构件,以及源码、作者信息、SCM、信息、许可证信息等。一般来说,简单的Java项目依赖的构件都可以在这里下载到。

    5.3 远程仓库

    如果 Maven 在中央仓库中也找不到依赖的文件,它会停止构建过程并输出错误信息到控制台。为避免这种情况,Maven 提供了远程仓库的概念,它是开发人员自己定制仓库。举例如下:

    <project xmlns="http://maven.apache.org/POM/4.0.0"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
       http://maven.apache.org/xsd/maven-4.0.0.xsd">
       <modelVersion>4.0.0</modelVersion>
       <groupId>com.companyname.projectgroup</groupId>
       <artifactId>project</artifactId>
       <version>1.0</version>
       <dependencies>
          <dependency>
             <groupId>com.companyname.common-lib</groupId>
             <artifactId>common-lib</artifactId>
             <version>1.0.0</version>
          </dependency>
       <dependencies>
       <repositories>
          <repository>
             <id>companyname.lib1</id>
             <url>http://download.companyname.org/maven2/lib1</url>
          </repository>
          <repository>
             <id>companyname.lib2</id>
             <url>http://download.companyname.org/maven2/lib2</url>
          </repository>
       </repositories>
    </project>
    

    PS: maven仓库默认在国外,使用相对较慢。我们可以更换为阿里云的仓库,具体方式请使用搜索引擎。

    5.4 maven依赖搜索仓库的顺序
    1. 在本地仓库中搜索,如果找不到,执行步骤 2,如果找到了则执行其他操作。
    2. 在中央仓库中搜索,如果找不到,并且有一个或多个远程仓库已经设置,则执行步骤 4,如果找到了则下载到本地仓库中以备将来引用。
    3. 如果远程仓库没有被设置,Maven 将简单的停滞处理并抛出错误(无法找.到依赖的文件)。
    4. 在一个或多个远程仓库中搜索依赖的文件,如果找到则下载到本地仓库以备将来引用,否则 Maven 将停止处理并抛出错误(无法找到依赖的文件)

    6、maven插件

    未完待续

    相关文章

      网友评论

          本文标题:maven总结

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