《Maven 实战》读书笔记(五) Maven的生命周期 和插件

2024-09-03 17:18

本文主要是介绍《Maven 实战》读书笔记(五) Maven的生命周期 和插件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. Maven的生命周期

Maven的生命周期其实是指它对所有的构建过程进行了反复的推敲、反思,之后总结了一套高度抽象过程。这个过程是高度完善的、容易扩展的。基本上包含了项目的清理、初始化、编译、测试、打包、集成测试、验证、部署、、站点生成等步骤,几乎所有的项目生命周期也就这样。Maven项目周期是一个抽象的概念,这个概念性的东西意味着它并不做任何实质性的事情,也就是说:它就像接口,只定义规范,具体细节它不管。具体的实现细节则交给了Maven的各个丰富的插件。Maven的插件机制有可能是跟Eclipse学的,基于一个内核core,定义一堆流程性的东西,让插件去实现这些规范。其他组织也可以根据这套规范插入自己的东西,形成有特色化的、自定制的Maven。

Maven有三套相互独立的生命周期,分别是:clean、default、site。clean主要是清理项目、default是Maven最核心的的构建项目、site是生成项目站点。每一个大的生命周期又分为很多个阶段。后面的阶段依赖于前面的阶段,这点有点像Ant的构建依赖。生命周期本身相互独立,用户可以仅仅调用生命周期的某一个阶段,也就是说用户调用了default周期的任何阶段,并不会触发clean周期以及site周期的任何事情。

2. Maven生命周期阶段详解

3大生命周期蕴含着小小的阶段,我们按顺序看一下

clean周期:

pre-clean:准备清理

clean:真正的清理工作

post-clean:执行清理后的一些后续工作

default周期:

validate:验证

initialize:初始化配置

generate-sources:生成源代码编译目录

process-sources:处理项目主资源文件,复制资源文件到outputclasspath

generate-resources:生成资源目录

process-resources:处理资源文件

complie:编译源代码

process-classes:处理编译后文件

generate-test-sources:生成测试目录

process-test-sources:处理项目测试资源文件,复制测试资源文件到outputclasspath

generate-test-resources:生成测试资源文件

process-test-resources:处理测试资源文件

test-compile:编译测试代码

process-test-classes:处理测试代码

test:单元测试运行测试代码

prepare-package:打包前的准备

package:将编译好的代码打包成为jar或者war或者ear等等

pre-integration-test:准备整体测试

integration-test:整体测试

post-integration-test:为整体测试收尾

verify:验证

install:安装到本地Maven库

deploy:将最终包部署到远程Maven仓库

site周期:

pre-site:准备生成站点

site:生成站点及文档

post-site:站点收尾

site-deploy:将生成的站点发布到服务器上

比如说在命令行执行了

mvn clean  


就是执行到clean周期的clean阶段。也就是说实际执行了pre-clean阶段与clean阶段。
mvn deploy  


就是执行了整个default生命周期
mvn clean deploy site-deploy  


这个就是执行了clean周期的前两个阶段、default周期的所有阶段、site周期的所有阶段。

3. Maven的插件机制

之前我们就说了Maven的生命周期仅仅是个抽象的标准,不干实事的,真正干事的人藏在了幕后,就是Maven插件。插件本身为了能够代码复用,往往一个插件实现了很多功能,这个如果我们做过Eclipse插件开发的人也许更清楚,比如一个Eclipse的SVN插件,即实现了可以查看远程SVN资源库的信息,也可以下载远程代码,还可以上传代码。这实际上是3个功能,而由一个jar实现。在Maven中,管这个叫做“目标”。比如maven-dependency-plugin基于项目依赖实现了很多事情,分析依赖、列出依赖树、分析依赖来源等等。每个功能对应着一个插件的目标,插件的目标越多,插件的功能越多。比如

mvn dependency:analyze  


就是使用maven-dependency-plugin插件的analyze目标,分析项目的依赖。
    [WARNING] Unused declared dependencies found:      [WARNING]    org.springframework:spring-core:jar:2.5.6:compile      [WARNING]    org.springframework:spring-beans:jar:2.5.6:compile  



Maven的生命周期与Maven插件是项目绑定的,Maven默认地将一些默认插件的目标与Maven的生命周期维系在了一起,比如default的compile这个阶段就是和maven-compiler-plugin这个插件的compile目标维系着不可分割的关系。前者是领导,复杂发号施令,指定规则,后者是小兵,专门根据任务干活儿的人。为了不让用户不用任何配置就能进行一般程度的项目构建,Maven默认给自己生命周期的核心阶段绑定了自己的插件。

clean如下:

生命周期阶段


插件目标

pre-clean

clean

maven-clean-plugin:clean

post-clean

site如下:

生命周期阶段

插件目标

pre-site

site

maven-site-plugin:site

post-site

site-deploy

maven-site-plugin:deploy

最麻烦的就是最核心的default

生命周期阶段


插件目标

process-resources

maven-resources-plugin:resources

compile

maven-compiler-pugin:compile

process-test-resources

maven-resources-plugin:testResources

test-compile

maven-compiler-plugin:testCompile

test

maven-surefire-plugin:testCompile

package

maven-jar-plugin:jar

install

maven-install-plugin:install

deploy

maven-deploy-plugin:deploy

其他没绑定插件的就是说没有什么实际行为。

在我们自己的项目中绑定插件,比如在pom.xml内容添加如下内容

    <build>          <resources>              <resource>                  <directory>src/main/resource</directory>              </resource>          </resources>          <plugins>              <plugin>                  <groupId>org.apache.maven.plugins</groupId>                  <artifactId>maven-source-plugin</artifactId>                  <version>2.1.1</version>                  <executions>                      <execution>                          <id>buildSource</id>                          <phase>verify</phase>                          <goals>                              <goal>jar-no-fork</goal>                          </goals>                          <inherited>false</inherited>                          <configuration>                          </configuration>                      </execution>                  </executions>              </plugin>          </plugins>      </build>  



之后执行命令
mvn verify 


看到输出文件夹就包含了我们的源代码source的jar。这个打包源代码的“目标”被绑定到了default周期的verify执行。还有一点就是有些插件一旦写上了pom.xml会有默认的绑定周期,比如就拿以上插件说事,如果将<phase>verify</phase>去掉,执行
mvn package



源代码依然输出,其实它默认适合default周期的package阶段绑定的。Goals代表该插件的某些目标(功能)。

插件还能进行全局性质的参数配置,参数是什么就不用多说了吧,大家接触linux的都知道吧。Configuration就是配置参数的。
    <plugin>          <groupId>org.apache.maven.plugins</groupId>          <artifactId>maven-compiler-plugin</artifactId>          <version>2.1</version>          <configuration>              <target>1.5</target>          </configuration>      </plugin> 



4. Maven插件的详细信息

如果想获取插件的详细信息,一种途径就是通过在线官网查询(google一下就知道了),一种就是利用它的另一个插件,maven-help-plugin。比如在命令行输入如下

    mvn help:describe -D plugin=org.apache.maven.plugins:maven-compiler-plugin:2.1   


效果如下,显示了一些插件的信息
    Name: Maven Compiler Plugin      Description: The Compiler Plugin is used to compile the sources of your        project.      Group Id: org.apache.maven.plugins      Artifact Id: maven-compiler-plugin      Version: 2.1      Goal Prefix: compiler      This plugin has 3 goals:      compiler:compile        Description: Compiles application sources      compiler:help        Description: Display help information on maven-compiler-plugin.          Call            mvn compiler:help -Ddetail=true -Dgoal=<goal-name>          to display parameter details.      compiler:testCompile        Description: Compiles application test sources.      For more information, run 'mvn help:describe [...] -Ddetail'  



需要注意的就是Goal Prefix: compiler这里,是代表该插件的目标前缀写法,我称之为目标简写,也就是说你可以简写为
mvn compiler:compile 


就可以使用maven的maven-compiler-plugin插件完成编译项目的功能了。其实使用 “插件:目标”的方式是适合该功能不方便与Maven生命周期绑定的情况下。

5. 总结

这次主要概括了Maven的生命周期以及它的插件机制和插件的使用。生命周期是Maven核心的东西,插件也是Maven核心的东西,所以还是有必要看看的。下次我们单独来看看之前没提到的解析机制,包括Maven仓库的依赖解析和Maven插件的解析机制。

这篇关于《Maven 实战》读书笔记(五) Maven的生命周期 和插件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1133553

相关文章

springboot项目redis缓存异常实战案例详解(提供解决方案)

《springboot项目redis缓存异常实战案例详解(提供解决方案)》redis基本上是高并发场景上会用到的一个高性能的key-value数据库,属于nosql类型,一般用作于缓存,一般是结合数据... 目录缓存异常实践案例缓存穿透问题缓存击穿问题(其中也解决了穿透问题)完整代码缓存异常实践案例Red

Spring Boot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)

《SpringBoot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)》:本文主要介绍SpringBoot拦截器Interceptor与过滤器Filter深度解析... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现与实

MyBatis分页插件PageHelper深度解析与实践指南

《MyBatis分页插件PageHelper深度解析与实践指南》在数据库操作中,分页查询是最常见的需求之一,传统的分页方式通常有两种内存分页和SQL分页,MyBatis作为优秀的ORM框架,本身并未提... 目录1. 为什么需要分页插件?2. PageHelper简介3. PageHelper集成与配置3.

基于C#实现MQTT通信实战

《基于C#实现MQTT通信实战》MQTT消息队列遥测传输,在物联网领域应用的很广泛,它是基于Publish/Subscribe模式,具有简单易用,支持QoS,传输效率高的特点,下面我们就来看看C#实现... 目录1、连接主机2、订阅消息3、发布消息MQTT(Message Queueing Telemetr

Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例

《Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例》本文介绍Nginx+Keepalived实现Web集群高可用负载均衡的部署与测试,涵盖架构设计、环境配置、健康检查、... 目录前言一、架构设计二、环境准备三、案例部署配置 前端 Keepalived配置 前端 Nginx

Python日期和时间完全指南与实战

《Python日期和时间完全指南与实战》在软件开发领域,‌日期时间处理‌是贯穿系统设计全生命周期的重要基础能力,本文将深入解析Python日期时间的‌七大核心模块‌,通过‌企业级代码案例‌揭示最佳实践... 目录一、背景与核心价值二、核心模块详解与实战2.1 datetime模块四剑客2.2 时区处理黄金法

SpringBoot实现接口数据加解密的三种实战方案

《SpringBoot实现接口数据加解密的三种实战方案》在金融支付、用户隐私信息传输等场景中,接口数据若以明文传输,极易被中间人攻击窃取,SpringBoot提供了多种优雅的加解密实现方案,本文将从原... 目录一、为什么需要接口数据加解密?二、核心加解密算法选择1. 对称加密(AES)2. 非对称加密(R

Maven 插件配置分层架构深度解析

《Maven插件配置分层架构深度解析》:本文主要介绍Maven插件配置分层架构深度解析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Maven 插件配置分层架构深度解析引言:当构建逻辑遇上复杂配置第一章 Maven插件配置的三重境界1.1 插件配置的拓扑

Spring Boot集成Logback终极指南之从基础到高级配置实战指南

《SpringBoot集成Logback终极指南之从基础到高级配置实战指南》Logback是一个可靠、通用且快速的Java日志框架,作为Log4j的继承者,由Log4j创始人设计,:本文主要介绍... 目录一、Logback简介与Spring Boot集成基础1.1 Logback是什么?1.2 Sprin

Idea插件MybatisX失效的问题解决

《Idea插件MybatisX失效的问题解决》:本文主要介绍Idea插件MybatisX失效的问题解决,详细的介绍了4种问题的解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录一、重启idea或者卸载重装MyBATis插件(无需多言)二、检查.XML文件与.Java(该文件后缀Idea可能会隐藏