Maven使用教程三:maven的生命周期及插件机制详解

前言

今天这个算是学习Maven的一个收尾文章,里面内容不局限于标题中提到的,后面还加上了公司实际使用的根据profile配置项目环境以及公司现在用的archetype 模板等例子。

后面还会总结一个大的思维导图记录下自己学习的概括。

Maven的生命周期介绍

先来复习几个命令:

  • mvn clean package:打包
  • mvn clean install:安装到本地
  • mven clean deploy:部署到远程仓库

mvn有三套完全独立的生命周期,clean、default和site
每套生命周期都会包含多个phase,每个phase又是由各种插件的goal来完成的。

phase可以理解为任务单元,生命周期是总任务,phase就是总任务分出来的一个个子任务,但是这些子任务是被规格化的,它可以同时被多个生命周期所包含,一个生命周期包含多个phase,phsse的执行时顺序的,一个phase可以绑定多个goal,至少一个。

goal是执行任务最小的单元,它可以绑定到任意的phase中,一个phase有一个或多个goal,goal也是按顺序执行的,一个phase被执行时,绑定到phase里的goal会按绑定的时间被顺序执行。

Maven的生命周期以及phase

clean的生命周期包含的phase如下:

  • pre-clean
  • clean
  • post-clean

default的生命周期包含的phase如下:

  • validate:校验这个项目的一些配置信息是否正确
  • initialize:初始化构建状态,比如设置一些属性,或者创建一些目录
  • generate-sources:自动生成一些源代码,然后包含在项目代码中一起编译
  • process-sources:处理源代码,比如做一些占位符的替换
  • generate-resources:生成资源文件,才是干的时我说的那些事情,主要是去处理各种xml、properties那种配置文件,去做一些配置文件里面占位符的替换
  • process-resources:将资源文件拷贝到目标目录中,方便后面打包
  • compile:编译项目的源代码
  • process-classes:处理编译后的代码文件,比如对java class进行字节码增强
  • generate-test-sources:自动化生成测试代码
  • process-test-sources:处理测试代码,比如过滤一些占位符
  • generate-test-resources:生成测试用的资源文件
  • process-test-resources:拷贝测试用的资源文件到目标目录中
  • test-compile:编译测试代码
  • process-test-classes:对编译后的测试代码进行处理,比如进行字节码增强
  • test:使用单元测试框架运行测试
  • prepare-package:在打包之前进行准备工作,比如处理package的版本号
  • package:将代码进行打包,比如jar包
  • pre-integration-test:在集成测试之前进行准备工作,比如建立好需要的环境
  • integration-test:将package部署到一个环境中以运行集成测试
  • post-integration-test:在集成测试之后执行一些操作,比如清理测试环境
  • verify:对package进行一些检查来确保质量过关
  • install:将package安装到本地仓库中,这样开发人员自己在本地就可以使用了
  • deploy:将package上传到远程仓库中,这样公司内其他开发人员也可以使用了

site生命周期的phase

  • pre-site
  • site
  • post-site
  • site-deploy

### 默认的phase和plugin

我们直接运行mvn clean package的时候,每个phase都是由插件goal来完成的,phase和plugin绑定的关系是什么了?

实际上,默认maven就绑定了一些plugin goal到phase上,比如:

类似于resources:resources这种格式,说的就是resources这个plugin的resources goal(resources功能,负责处理资源文件)

maven的命令行与生命周期

比如我们执行mvn clean package生命周期是什么样的?

clean是指的clean生命周期中的clean phase
package是指default生命周期中的package phase

此时就会执行clean生命周期中在clean phase之前的所有phase和clean phase(pre-clean、clean)
同事执行default生命周期中在package phase之前的所有phase和package phase

clean默认绑定的是clean:clean, clean plugin的clean goal,所以就会去执行clean插件的clean goal。

具体执行流程如下图:

maven中使用plugin实战

需求:项目中有mybatis 自动生成代码,希望执行某些maven命令可以自动根据指定的表设置 生成对应代码。

添加mybatis.generator的plugin,然后配置generate goal

<build>
        <plugins>
            <plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.3.2</version>
                <configuration>
                    <configurationFile>mybatis-generator-config.xml</configurationFile>
                    <verbose>true</verbose>
                    <overwrite>true</overwrite>
                </configuration>
                <executions>
                    <execution>
                        <id>Generate MyBatis Artifacts</id>
                        <goals>
                            <goal>generate</goal>
                        </goals>
                    </execution>
                </executions>
                <dependencies>
                    <dependency>
                        <groupId>org.mybatis.generator</groupId>
                        <artifactId>mybatis-generator-core</artifactId>
                        <version>1.3.2</version>
                    </dependency>
                    <dependency>
                        <groupId>mysql</groupId>
                        <artifactId>mysql-connector-java</artifactId>
                        <version>${mysql-connector.version}</version>
                    </dependency>
                    <dependency>
                        <groupId>com.wangmeng.game</groupId>
                        <artifactId>game-wangmeng-common</artifactId>
                        <version>1.0-SNAPSHOT</version>
                    </dependency>
                </dependencies>
            </plugin>
        </plugins>
    </build>

再看看mybatis-generator-config.xml配置的sql信息:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE generatorConfiguration PUBLIC
        "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
        "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd" >
<generatorConfiguration>
    <context id="context" targetRuntime="MyBatis3">
        <plugin type="org.mybatis.plugin.PaginationPlugin">
        </plugin>

        <commentGenerator>
            <property name="suppressAllComments" value="false"/>
            <property name="suppressDate" value="true"/>
        </commentGenerator>

        <!-- 数据库的相关配置 -->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
                        connectionURL="jdbc:mysql://ip:3306/db?useUnicode=true" userId="root"
                        password=""/>

        <javaTypeResolver>
            <property name="forceBigDecimals" value="false"/>
        </javaTypeResolver>

        <!-- 实体类生成的位置 -->
        <javaModelGenerator targetPackage="com.wangmeng.game.league.entity"
                            targetProject="game-wangmeng-entity/src/main/java">
            <property name="enableSubPackages" value="false"/>
            <property name="trimStrings" value="true"/>
        </javaModelGenerator>

        <!-- *Mapper.xml 文件的位置 -->
        <sqlMapGenerator targetPackage="mapper" targetProject="game-wangmeng-dao/src/main/resources">
            <property name="enableSubPackages" value="false"/>
        </sqlMapGenerator>

        <!-- Mapper 接口文件的位置 -->
        <javaClientGenerator targetPackage="com.wangmeng.game.league.dao"
                             targetProject="game-wangmeng-dao/src/main/java"
                             type="XMLMAPPER">
            <property name="enableSubPackages" value="false"/>
        </javaClientGenerator>

        <!-- 相关表的配置 -->
        <table tableName="t_table" domainObjectName="TableEntity" enableCountByExample="true"
               enableDeleteByExample="true"
               enableSelectByExample="true"
               enableUpdateByExample="true">
            <generatedKey column="id" sqlStatement="MySql" identity="true"/>
        </table>

    </context>
</generatorConfiguration>

我们可以在idea maven中看到我们配置好的plugin了,然后点击执行即可:

plugin:mybatis-generator
goal:generate

利用profile区分不同环境

??? <profiles>
    <profile>
        <!--local env-->
        <id>dev</id>
        <properties>
            <profiles.active>dev</profiles.active>
        </properties>
        <activation>
           <activeByDefault>true</activeByDefault>
        </activation>
    </profile>
    <profile>
        <!--test env-->
        <id>test</id>
        <properties>
            <profiles.active>test</profiles.active>
        </properties>
    </profile>
    <profile>
        <!--UT env-->
        <id>ut</id>
        <properties>
            <profiles.active>ut</profiles.active>
        </properties>
    </profile>
</profiles>

这里默认使用的是dev环境,通过<activation>配置的。

maven版本管理和git之间的关系

一图流:

maven高阶:archetype模板

artchetype其实就是个maven项目模板

拿一个我们公司现在用的东西举例,当我们创建一个全新的项目时,不可能再重新new一个全新的maven项目了,公司其实早就为我们提供了项目生成的脚手架,只需要执行一段maven命令即可生成好一个全新的项目,项目结构在这里都是给定义好了的。

这样的好处一是方便我们创建项目,二是方便公司规范的执行和管理。

这里直接拿公司的一个artchetype的一个模板来演示(关键信息已经马赛克)

1,自己可以选择生成一个maven archetype quickstart或者maven archetype webapp项目

然后用mvn deploy?即可把archetype jar包上传到maven私服

2,使用自定义的maven archetype

公司里面是直接封装了一个bat可执行文件,执行方式为

cmd到CreateProject-latest.bat目录,执行命令CreateProject-latest.bat 项目名?包名,如CreateProject-latest.bat?shop-report report 即可使用最新版本的脚手架生成工程 xx-spring-cloud-api-shop-report,包名为com.xx.report。把项目copy到你的喜欢的地址,再导入到eclipse或idea中即可。请手动添加gitignore。请修改父项目版本为最新的release版本。

CreateProject-latest.bat

echo on & color 0A
setlocal enabledelayedexpansion

if "%1"=="" goto BLANK
if "%2"=="" goto BLANK

set ProjectName=%1
set packageName=%2
set archetypeVersion=LATEST

mvn dependency:copy -Dartifact=com.xx:xx-archetype-springcloud-archetype:%archetypeVersion% -Dmdep.stripVerison=true & echo Y | mvn archetype:generate -DarchetypeCatalog=local -DarchetypeGroupId=com.tuhu -DarchetypeArtifactId=xx-archetype-springcloud-archetype -DarchetypeVersion=%archetypeVersion% -DgroupId=com.tuhu -DartifactId=%ProjectName% -Dversion=0.0.1-SNAPSHOT -Dpackage=com.xx.%packageName% & rd/s/q ${project.basedir} & rd/s/q %ProjectName%\.idea & ren %ProjectName% xx-spring-cloud-api-%ProjectName%

感兴趣的小伙伴可关注个人公众号:壹枝花算不算浪漫

原文地址:https://www.cnblogs.com/wang-meng/p/11902415.html

时间: 2024-11-05 14:47:36

Maven使用教程三:maven的生命周期及插件机制详解的相关文章

Maven核心概念之仓库,生命周期与插件

宏观图 一.仓库 统一存储全部Maven项目共享的构建的位置就是仓库. 仓库分为本地仓库和远程仓库.远程仓库又分为中央仓库(中央仓库是Maven核心自带的远程仓库),伺服(还有一种特殊的远程仓库,为节省宽带和时间,在局域网内架设的一个私有的仓库server,用其代理全部的外部的远程仓库.内部项目也能部署到伺服上),其它公开的远程仓库(常见的由Java.net Maven库,Jboss Maven库). Maven依据坐标寻找构件的时候,它首先会查看本地仓库,假设本地仓库存在此构件,则直接使用:假

笔记:Maven 生命周期与命令行详解

Maven 拥有三套相互独立的生命周期,分别是 clean.default和site,clean 生命周期的目的是清理项目,default 生命周期的目的是构建项目,而site生命周期的目的是建立项目站点,每个生命周期包含一些阶段,这些阶段是有顺序的,并且后面的阶段依赖前面的阶段,用户和Maven最直接的交互方式就是调用这些生命周期阶段. clean 生命周期:包含的阶段有 pre-clean.clean 和 post-clean pre-clean:执行一些清理前需要完成的工作 clean:清

【读书笔记】《Maven实战》 第7章 生命周期与插件

7.1什么是生命周期 软件开发人员每天都在对项目进行清理.编译.测试及部署,Maven生命周期是对所有构建过程进行抽象和统一,含项目的清理.初始化.编译.测试.打包.集成测试.验证.部署和站点生成等几乎所有构建步骤. 7.2生命周期详解 7.2.1三套相互独立的生命周期 clean:目的是清理项目 default:目的是构建项目 site:目的是建立项目站点 两个原则 a)三套生命周期相互独立,不会相互影响 b)每个生命周期包含一些阶段(phase),阶段间有顺序且后面的阶段依赖于前面的阶段 7

Activity的生命周期和启动模式详解

Activity生命周期经典图解: 按键对生命周期的影响: BACK键: 当我们按BACK键时,我们这个应用程序将结束,这时候我们将先后调用onPause()->onStop()->onDestory()三个方法. 再次启动App时,会执行onCreate()->onStart()->onResume() HOME键: 当我们打开应用程序时,比如浏览器,我正在浏览NBA新闻,看到一半时,我突然想听歌,这时候我们会选择按HOME键,然后去打开音乐应用程序,而当我们按HOME的时候,A

vue2.0项目实战(3)生命周期和钩子函数详解

最近的项目都使用vue2.0来开发,不得不说,vue真的非常好用,大大减少了项目的开发周期.在踩坑的过程中,因为对vue的生命周期不是特别了解,所以有时候会在几个钩子函数里做一些事情,什么时候做,在哪个函数里做,我们不清楚. 下面来总结一下vue的生命周期. vue生命周期简介 咱们从上图可以很明显的看出现在vue2.0都包括了哪些生命周期的函数了. 生命周期探究 对于执行顺序和什么时候执行,看上面两个图基本有个了解了.下面我们将结合代码去看看钩子函数的执行. <!DOCTYPE html>

深入理解maven及应用(一):生命周期和插件

在项目里用了快一年的maven了,近期突然发现maven项目在eclipse中build时很慢,由于经经常使用clean install命令来build项目,也没有管那么多,但近期实在受不了乌龟一样的build速度,于是下定决心再看看<maven实战>吧, 对于我来说,maven最基本的作用有两个方面,一个是对jar包的依赖解决功能,自己管理jar包.还有一个功能就是项目的构建,打包部署.如今我认为最重要的还是maven的生命周期和插件机制,以下就来总结一下吧. 參考url:http://ma

Maven入门教程三----生命周期和插件

生命周期和插件   Maven定义了三套生命周期:clean.default.site,每个生命周期都包含了一些阶段(phase). 三套生命周期相互独立,但各个生命周期中的phase却是有顺序的,且后面的phase依赖于前面的phase. 执行某个phase时,其前面的phase会依顺序执行,但不会触发另外两套生命周期中的任何phase. 如下图: -------------------------------------------------------------------------

Maven系列学习(三)Maven生命周期和插件

Maven生命周期和插件 Maven另外的两个核心概念就是生命周期和插件,Maven的生命周期都是抽象的,其实实际行为都是由插件来完成的,生命周期和插件两者协同工作 1.生命周期 Maven的生命周期就是为了对所有的构建过程进行抽象和统一,这个生命周期包含了项目的清理,初始化,编译,测试,打包,集成测试,验证,部署和站点生成等几乎所有构建步骤,Maven的生命周期是抽象的,这意味着生命周期本身不做任何实际的工作,在Maven的设计中,实际的任务都是交给插件来完成的 一次构建(build):ini

Maven学习(四):生命周期与maven插件

一.maven 生命周期 (一)简介 Maven强大的一个重要的原因是它有一个十分完善的生命周期模型(lifecycle),这个生命周期可以从两方面来理解: 1.顾名思义,运行Maven的每个步骤都由它来定义的,这种预定义的默认行为使得我们使用Maven变得简单,相比而言,Ant的每个步骤都要你手工去定义. 2.这个模型是一种标准,在不同的项目中,使用Maven的接口是一样的,这样就不用去仔细理解每个项目的构建了,一般情况下,mvn clean install  这样的命令是通用的. 3.一个M