Maven实践(八)---插件的生命周期
2017-03-07 21:50
316 查看
Maven拥有三套相互独立的生命周期,分别是clean、default和site,每一个生命周期包含一个阶段(phase),阶段是顺序执行的,并且后面的阶段依赖前面的阶段
pre-clean:执行一些清理前需要完成的工作
clean:清理上一次构建生成的文件——maven-clean-pluge:clean
post-clean:执行一些清理后需要完成的工作
validate(使合法化)
initialize(初始化)
generate-sources(生成源文件)
process-sources:处理项目主资源文件,对
generate-resources(生成资源文件)
process-resources:(处理资源文件)——maven-resources-pluge:resources
compile:编译项目主源码,编译
process-classes(处理类文件)
generate-test-sources(生成测试源文件)
process-test-sources:处理项目测试源文件,对
generate-test-resources(生成测试资源文件)
process-test-resources(处理测试资源文件)
test-compile:编译项目的测试代码,编译
process-test-class(处理测试类文件)
test:使用单元测试框架运行测试,测试代码不会会被打包或部署——maven-surefire-pluge:test
prepare-package(准备打包)
package:接受编译好的代码,打包成可发布的格式,如JAR——maven-jar-pluge:jar
pre-integration-test(预集成测试)
integration-test(集成测试)
post-integration-test(集成测试后)
verify(核实)
install将包安装在Maven本地仓库,供本地其他Maven项目使用——maven-install-pluge:install
deploy:将最终的包复制到远程仓库,供其他开发人员和Maven项目使用——maven-deploy-pluge:deploy
pre-site:执行一些在生成项目站点之前需要完成的工作
site:生成项目站点文档——maven-site-pluge:site
post-site:执行一些在生成项目站点之后需要完成的工作
site-deploy将生成的项目站点发布到服务器上——maven-site-pluge:deploy
具体功能的命令行实现,使用冒号分隔,冒号前是插件前缀,冒号后是给插件的目标
生命周期的某个阶段和插件的目标相互绑定,以完成某个具体的构建任务
Maven在核心为一些主要的生命周期阶段绑定了很多插件,当用户通过命令行调用声明周期阶段的时候,对应的插件目标就会执行相应的任务
自定义绑定的插件,应该声明一个非快照版本
4000
中使用-D参数,并伴随一个参数键=参数值的形式来配置插件目标的参数
这样不论是绑定在compile阶阶段还是test-compiler阶段的任务,都能够使用该配置,基于Java1.5版本进行编译
与依赖构件一样,插件构件同样基于坐标存储在Maven仓库中(当需要的时候,Maven会从本地仓库寻找插件,如果不存在,则从远程仓库查找)
Tips:Maven会区别对待依赖的远程仓库和插件的远程仓库,当需要的插件不在本地是,不会去依赖的远程仓库查找
插件仓库配置代码:
除了pluginRepositories元素和pluginRepository元素的不同,其他和依赖的远程仓库配置一样
clean生命周期
目的:清理项目pre-clean:执行一些清理前需要完成的工作
clean:清理上一次构建生成的文件——maven-clean-pluge:clean
post-clean:执行一些清理后需要完成的工作
default生命周期
目的:构建项目validate(使合法化)
initialize(初始化)
generate-sources(生成源文件)
process-sources:处理项目主资源文件,对
src/main/resoureces目录的内容进行变量替换等工作后,复制到项目输出的主classpath目录中
generate-resources(生成资源文件)
process-resources:(处理资源文件)——maven-resources-pluge:resources
compile:编译项目主源码,编译
src/main/java,目录下的Java文件至项目输出的主classpath目录中——maven-complier-pluge:compile
process-classes(处理类文件)
generate-test-sources(生成测试源文件)
process-test-sources:处理项目测试源文件,对
src/test/resources目录下的内容进行变量替换等工作后,复制到项目输出的测试classpath目录中——maven-resources-pluge:testResources
generate-test-resources(生成测试资源文件)
process-test-resources(处理测试资源文件)
test-compile:编译项目的测试代码,编译
sre/test/java目录下的Java文件至项目输出的测试classpath目录中——maven-complier-pluge:testComplie
process-test-class(处理测试类文件)
test:使用单元测试框架运行测试,测试代码不会会被打包或部署——maven-surefire-pluge:test
prepare-package(准备打包)
package:接受编译好的代码,打包成可发布的格式,如JAR——maven-jar-pluge:jar
pre-integration-test(预集成测试)
integration-test(集成测试)
post-integration-test(集成测试后)
verify(核实)
install将包安装在Maven本地仓库,供本地其他Maven项目使用——maven-install-pluge:install
deploy:将最终的包复制到远程仓库,供其他开发人员和Maven项目使用——maven-deploy-pluge:deploy
site生命周期
目的:建立项目站点pre-site:执行一些在生成项目站点之前需要完成的工作
site:生成项目站点文档——maven-site-pluge:site
post-site:执行一些在生成项目站点之后需要完成的工作
site-deploy将生成的项目站点发布到服务器上——maven-site-pluge:deploy
插件目标
Mavan的具体任务由插件完成,插件中的每一个功能,就是一个插件的目标具体功能的命令行实现,使用冒号分隔,冒号前是插件前缀,冒号后是给插件的目标
生命周期的某个阶段和插件的目标相互绑定,以完成某个具体的构建任务
Maven在核心为一些主要的生命周期阶段绑定了很多插件,当用户通过命令行调用声明周期阶段的时候,对应的插件目标就会执行相应的任务
自定义绑定
<build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-source-plugin</artifactId> <version>2.1.1</version> <executions> <execution> <id>attach-sources</id> <phase>verify<phase> <goals> <goal>jar-no-fork<goal> </goals> </execution> </executions> </plugin> </plugins> </build>
自定义绑定的插件,应该声明一个非快照版本
命令行插件配置
在Maven命令4000
中使用-D参数,并伴随一个参数键=参数值的形式来配置插件目标的参数
POM中插件全局配置
<build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>2.1</version> <configuration> <source>1.5</source> <target>1.5<target> </configuration> </plugin> </plugins> </build>
这样不论是绑定在compile阶阶段还是test-compiler阶段的任务,都能够使用该配置,基于Java1.5版本进行编译
POM中插件任务配置
<build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-antrun-plugin</artifactId> <version>1.3</version> <executions> <execution> <id>ant-validate</id> <phase>validate<phase> <goals> <goal>run<goal> </goals> <configuration> <task> <echo>I'm bound to validate phase.</echo> </task> </configuration> </execution> </executions> </plugin> </plugins> </build>
插件解析机制
Maven不需要用户提供完整的插件坐标信息,就可以解析正确的插件,但是也存在问题与依赖构件一样,插件构件同样基于坐标存储在Maven仓库中(当需要的时候,Maven会从本地仓库寻找插件,如果不存在,则从远程仓库查找)
Tips:Maven会区别对待依赖的远程仓库和插件的远程仓库,当需要的插件不在本地是,不会去依赖的远程仓库查找
插件仓库配置代码:
<pluginRepositories> <pluginRepository> <id>centrol</id> <name>Maven Plugin Repository</name> <url>http://repo1.maven.org/maven2/</url> <lauout>defalut</layout> <snapshots> <enabled>false</enabled> </snapshots> <releases> <updatePolicy>never</updatePolicy> </releases> </snapshots> </pluginRepository> </pluginRepositories>
除了pluginRepositories元素和pluginRepository元素的不同,其他和依赖的远程仓库配置一样
插件的解析
插件的解析过程和依赖的解析过程基本一致相关文章推荐
- Maven的生命周期和maven-assembly-plugin插件使用
- Maven3实战笔记04Maven的生命周期和插件
- Maven入门指南⑦:Maven的生命周期和插件
- maven学习--生命周期和插件
- maven详解之生命周期与插件(二)
- 是goal还是phase?Maven插件(plugin)goal的执行与生命周期(lifecycle)phase的关系
- Maven-生命周期和插件
- maven的生命周期和插件
- maven教程之四生命周期和插件
- Maven 生命周期与插件
- maven的生命周期和插件
- Maven系列学习(5)-生命周期及插件
- Maven 实战 04 生命周期和插件
- 项目构建之maven篇:6.生命周期与插件
- maven生命周期与插件
- Maven生命周期和插件
- Maven--生命周期和插件(四)
- 读书笔记:maven生命周期和插件
- maven插件与生命周期
- Maven中的插件和生命周期