maven详解之生命周期与插件(二)

插件配置

定义解释:插件目标

当我们了解了maven插件之后,我们发现如果为每一个功能编写一个独立的插件显然是不可取的,因为这些任务背后有很多可以复用的代码,因此,把这些功能聚集在一个插件里,每一个功能我们就称之为一个插件目标。

举个例子:

maven-dependency-plugin有十多个目标,每个目标对应了一个功能

分析项目依赖:dependency:analyze

列出项目依赖树:dependency: tree

列出项目所有已解析的依赖:dependency:list

POM中插件全局配置

有些参数的值从项目的创建到项目发布都不会改变,或者说很少改变,对于这种情况,就可以在pom.xml中进行全局配置。

例:配置一个通用的Java编译版本

        <build>
		<plugins>
			<plugin>
				<groupId>org.apache.maven.plugins</groupId>
				<artifactId>maven-compiler-plugin</artifactId>
				<version>3.1</version>
				<configuration>
					<source>1.6</source>
					<target>1.6</target>
				</configuration>
			</plugin>
		</plugins>
	</build>

这样,不管绑定到compile阶段的maven-compiler-plugin: compile 还是绑定到test-compiler 阶段的maven-compiler-plugin: testCompiler 任务,就都能够使用该配置,基于Java1.6版本进行编译。

POM中插件任务配置

获取插件信息

在线插件信息

Maven插件的来源:基本所有主要的maven插件都来自于Apache和CodeHaus

因为maven本身是属于Apache的,所有它有很多官方的插件,而且他们具有很好的稳定性

除了Apache之外,托管于Codehaus上的Mojo项目也提供了大量的maven插件。(注:这些插件的文档和可靠性相对较差,使用的时候出现问题,只能自己查看源码)

插件解析机制和常见问题

与依赖构件一样,插件构件同样基于坐标存储在Maven仓库中。在需要的时候,Maven会从本地仓库寻找插件,如果不存在,则从远程插件仓库查找。找到插件之后,再下载到本地仓库使用

注:依赖的远程仓库    !=  插件的远程仓库,Maven会区别对待他们。

Maven需要的依赖在本地仓库中不存在时,Maven去配置的远程仓库中查找

Maven需要的插件在本地仓库中不存在时,Maven不会去这些远程仓库查找。

如何配置插件的远程仓库

Maven的插件远程仓库使用<pluginRepositories>和><pluginRepository>进行配置

Maven内置的插件远程仓库配置如下:它关闭了对SNAPSHOT的支持,防止不稳定的构建

<pluginRepositories>
		<pluginRepository>
			<id>central</id>
			<name>Maven Plugin Repository</name>
			<url>http://repo1.maven.org/maven2</url>
			<layout>default</layout>
			<snapshots>
				<enabled>false</enabled>
			</snapshots>
			<releases>
				<updatePolicy>never</updatePolicy>
			</releases>
		</pluginRepository>
	</pluginRepositories>

简单配置:

1.2省略groupId配置:

Maven针对其官方的插件提供了一种简单的配置策略,其官方的groupId为:org.apache.maven.plugins,在配置的时候可以省略该配置,Maven在解析该插件的时候,会自动用默认的groupId补齐。但是一般情况下不推荐此种用法,因为只剩下了一行配置,而且容易对新手造成费解。

2.省略版本配置:

maven的POM是采用了继承的机制(在maven的聚合与继承中有详细介绍),Maven中有一个超级POM,所有的项目都继承了这个超级POM的配置,因此用户不加任何配置,Maven使用核心插件的时候,他们的版本就已经确定了。

maven-clean-plugin

maven-compiler-plugin

maven-surefire-plugin

如果我们在配置的时候没有配置插件的版本,Maven会遍历本地仓库和所有远程插件仓库,将该路径下的仓库元数据归并后,就能计算出latest和release版本。

在Maven2中::::如果不配置版本,那么会默认的被解析到latest版本,这个版本可能会出现潜在的问题,比如说,这个版本是快照版本

在Maven3中::::如果不配置版本,那么会默认的被解析到release版本,这样就解决了稳定性问题,但是这也可能存在潜在问题,比如说,新版本的行为与旧版本的行为发生了变化,这样也会出现构建失败

所以:使用插件的时候,应该显示的设定版本。

佛之孝:众生皆父母,百善孝为先。

明白心佛众生三无差别,同体名大悲的道理,才知道,关爱他人就是关爱自己,救度他人就是救度自己,对人好,才是对自己好,于是,把众生都当做自己的父母来救度,此为佛之孝道。

maven详解之生命周期与插件(二)

时间: 2024-12-26 14:04:09

maven详解之生命周期与插件(二)的相关文章

maven详解之生命周期与插件(一)

Maven是一个优秀的项目管理工具,它能够帮你管理编译.报告.文档等. Maven的生命周期: maven的生命周期是抽象的,它本身并不做任何的工作.实际的工作都交由"插件"来完成. maven的每个构建步骤都可以绑定一个或多个插件行为,而且maven为大多数的构建步骤编写并绑定了默认插件. 三套生命周期: clean.default.site clean: 主要目的是清理项目 pre-clean: 执行一些清理前需要完成的工作 clean: 清理上一次构建生成的文件 post-cle

maven详解之生命周期与插件

Maven是一个优秀的项目管理工具,它能够帮你管理编译.报告.文档等. Maven的生命周期: maven的生命周期是抽象的,它本身并不做任何的工作.实际的工作都交由"插件"来完成. maven的每个构建步骤都可以绑定一个或多个插件行为,而且maven为大多数的构建步骤编写并绑定了默认插件. 三套生命周期: clean.default.site clean: 主要目的是清理项目 pre-clean: 执行一些清理前需要完成的工作 clean: 清理上一次构建生成的文件 post-cle

Vue 实例详解与生命周期

Vue 实例详解与生命周期 Vue 的实例是 Vue 框架的入口,其实也就是前端的 ViewModel,它包含了页面中的业务逻辑处理.数据模型等,当然它也有自己的一系列的生命周期的事件钩子,辅助我们进行对整个 Vue 实例生成.编译.挂着.销毁等过程进行 js 控制. Vue 实例初始化的选项配置对象详解 前面我们已经用了很多次 new Vue({...})的代码,而且 Vue 初始化的选项都已经用了data.methods.el.computedd等,估计您看到这里时,应该已经都明白了他们的作

maven的仓库、生命周期与插件

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

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

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

【05】Vue 之 实例详解与生命周期

Vue的实例是Vue框架的入口,其实也就是前端的ViewModel,它包含了页面中的业务逻辑处理.数据模型等,当然它也有自己的一系列的生命周期的事件钩子,辅助我们进行对整个Vue实例生成.编译.挂着.销毁等过程进行js控制. 5.1. Vue实例初始化的选项配置对象详解 前面我们已经用了很多次 new Vue({...})的代码,而且Vue初始化的选项都已经用了data.methods.el.computedd等,估计您看到这里时,应该已经都明白了他们的作用,我们就详细讲解一下他们的使用情况.更

Vue入门系列(五)Vue实例详解与生命周期

[入门系列] [本文转自] http://www.cnblogs.com/fly_dragon Vue的实例是Vue框架的入口,其实也就是前端的ViewModel,它包含了页面中的业务逻辑处理.数据模型等,当然它也有自己的一系列的生命周期的事件钩子,辅助我们进行对整个Vue实例生成.编译.挂着.销毁等过程进行js控制. 5.1. Vue实例初始化的选项配置对象详解 前面我们已经用了很多次 new Vue({...})的代码,而且Vue初始化的选项都已经用了data.methods.el.comp

【Vue】详解Vue生命周期

Vue实例的生命周期全过程(图) (这里的红边圆角矩形内的都是对应的Vue实例的钩子函数) 在beforeCreate和created钩子函数间的生命周期 在beforeCreate和created之间,进行数据观测(data observer) ,也就是在这个时候开始监控data中的数据变化了,同时初始化事件 created钩子函数和beforeMount间的生命周期 对于created钩子函数和beforeMount间可能会让人感到有些迷惑,下面我就来解释一下: el选项的有无对生命周期过程

详解Vue生命周期---1

目录 Vue实例的生命周期全过程(图) 在beforeCreate和created钩子函数间的生命周期 created钩子函数和beforeMount间的生命周期 el选项的有无对生命周期过程的影响 template参数选项的有无对生命周期的影响 Vue的编译过程——把模板编译成 render 函数 beforeMount和mounted钩子函数间的生命周期 beforeUpdate钩子函数和updated钩子函数间的生命周期 beforeDestroy和destroyed钩子函数间的生命周期