信步漫谈之Maven——生命周期和插件


目录
  • 1 maven 的三大生命周期
  • 2 maven 内置变量
  • 3 maven 的插件
  • 4 插件仓库
  • 5 插件目标
  • 6 自定义绑定
  • 7 插件配置
  • 8 maven 常用插件
  • 9 参考资料(感谢)


1 maven 的三大生命周期

maven 有三个标准的生命周期,每个生命周期中都包含着一系列的阶段( phase )。这些 phase 就相当于 Maven 提供的统一的接口。
Maven的生命周期是抽象的,其中的具体任务都交由插件来完成。这些 phase 的实现由 Maven 的插件来完成。
每个生命周期的阶段是有顺序的,后面的阶段依赖于前面的阶段。在一个生命周期中,运行某个阶段的时候,它之前的所有阶段都会被运行,也就是说,mvn clean 等同于 mvn pre-clean clean ,如果我们运行 mvn post-clean ,那么 pre-clean,clean 都会被运行。这是Maven很重要的一个规则,可以大大简化命令行的输入。
三大生命周期是相互独立的,一个生命周期的执行不会触发另外两个生命周期中的 phase。

  • clean 生命周期:清理项目,包含三个 phase。
    • pre-clean:执行清理前需要完成的工作
    • clean:清理上一次构建生成的文件
    • post-clean:执行清理后需要完成的工作
  • default(或 build) 生命周期:构建项目,重要的 phase 如下。
    • validate:验证工程是否正确,所有需要的资源是否可用。
    • compile:编译项目的源代码。
    • test:使用合适的单元测试框架来测试已编译的源代码。这些测试不需要已打包和布署。
    • package:把已编译的代码打包成可发布的格式,比如jar。
    • integration-test:如有需要,将包处理和发布到一个能够进行集成测试的环境。
    • verify:运行所有检查,验证包是否有效且达到质量标准。
    • install:把包安装到maven本地仓库,可以被其他工程作为依赖来使用。
    • deploy:在集成或者发布环境下执行,将最终版本的包拷贝到远程的repository,使得其他的开发者或者工程可以共享。
  • site生命周期:建立和发布项目站点,phase如下
    • pre-site:生成项目站点之前需要完成的工作
    • site:生成项目站点文档
    • post-site:生成项目站点之后需要完成的工作
    • site-deploy:将项目站点发布到服务器

2 maven 内置变量

  • ${basedir}表示项目根目录,即包含pom.xml文件的目录;
  • ${version}表示项目版本;
  • ${project.basedir}同${basedir};
  • ${project.baseUri}表示项目文件地址;
  • ${maven.build.timestamp}表示项目构件开始时间;
  • ${maven.build.timestamp.format}表示属性${maven.build.timestamp}的展示格式,默认值为yyyyMMdd-HHmm,可自定义其格式,其类型可参考java.text.SimpleDateFormat。
  • ${project.build.directory}表示主源码路径;
  • ${project.build.sourceEncoding}表示主源码的编码格式;
  • ${project.build.sourceDirectory}表示主源码路径;
  • ${project.build.finalName}表示输出文件名称;
  • ${project.version}表示项目版本,与${version}相同;
  • ${project.xxx} 当前pom文件的任意节点的内容
  • ${env.xxx} 获取系统环境变量。
  • ${settings.xxx} 指代了settings.xml中对应元素的值。

3 maven 的插件

官网插件列表
我们在输入 mvn 命令的时候 比如 mvn clean,clean 对应的就是 Clean 生命周期中的 clean 阶段。但是 clean 的具体操作是由 maven-clean-plugin 来实现的。
所以说 Maven 生命周期的每一个阶段的具体实现都是由 Maven 插件实现的。
Maven 实际上是一个依赖插件执行的框架,每个任务实际上是由插件完成。
插件通常提供了一个目标的集合,并且可以使用下面的语法执行:

mvn [plugin-name]:[goal-name]

Maven的核心文件很小,主要的任务都是由插件来完成。定位到:%本地仓库%\org\apache\maven\plugins,可以看到一些下载好的插件。

4 插件仓库


    
        central
        Central Repository
        http://repo.maven.apache.org/maven2
        default
        
            false
        
        
            never
        
    

5 插件目标

一个插件通常可以完成多个任务,每一个任务就叫做插件的一个目标(goal)。如执行mvn install命令时,调用的插件和执行的插件目标如下,例如 maven-compiler-plugin:3.1:compile 之后的 compile 即为插件目标。

[INFO] ------------------------------------------------------------------------
[INFO] Building maven-demo01 1.0.0-SNAPSHOT
[INFO] ------------------------------------------------------------------------
[INFO] 
[INFO] --- maven-resources-plugin:2.6:resources (default-resources) @ maven-demo01 ---
[WARNING] Using platform encoding (UTF-8 actually) to copy filtered resources, i.e. build is platform dependent!
[INFO] Copying 0 resource
[INFO] 
[INFO] --- maven-compiler-plugin:3.1:compile (default-compile) @ maven-demo01 ---
[INFO] Nothing to compile - all classes are up to date
[INFO] 
[INFO] --- maven-resources-plugin:2.6:testResources (default-testResources) @ maven-demo01 ---
[WARNING] Using platform encoding (UTF-8 actually) to copy filtered resources, i.e. build is platform dependent!
[INFO] skip non existing resourceDirectory XXXXXXXX
[INFO] 
[INFO] --- maven-compiler-plugin:3.1:testCompile (default-testCompile) @ maven-demo01 ---
[INFO] Nothing to compile - all classes are up to date
[INFO] 
[INFO] --- maven-surefire-plugin:2.12.4:test (default-test) @ maven-demo01 ---
[INFO] Tests are skipped.
[INFO] 
[INFO] --- maven-jar-plugin:2.4:jar (default-jar) @ maven-demo01 ---
[INFO] 
[INFO] --- maven-install-plugin:2.4:install (default-install) @ maven-demo01 ---

Maven对一些生命周期的阶段(phase)默认绑定了插件目标,通过 maven 的目标前后缀写法,目标前缀是插件的简易别名,目标后缀是插件的工作目标(工作任务),是配置和使用插件的一种简化方式。官网插件前缀介绍

名称 目标前后缀写法
process-test-resources resources:testResources
test-compile compiler:testCompile
compile compile:compile
install install:install
test surefire:test

6 自定义绑定

用户可以根据需要将任何插件目标绑定到任何生命周期的阶段,如:将 maven-source-plugin 的 jar-no-fork 目标绑定到 default 生命周期的 package 阶段,这样,以后在执行 mvn package 命令打包项目时,在 package 阶段之后会执行源代码打包,生成如:ehcache-core-2.5.0-sources.jar 形式的源码包。


    
        
            org.apache.maven.plugins
            maven-source-plugin
            2.2.1
            
                
                    attach-source
                    
                    package
                    
                    	
                        jar-no-fork
                    
                
            
        
    

7 插件配置

Maven插件高度易扩展,可以方便的进行自定义配置(例如配置 maven-compiler-plugin 插件编译源代码的 JDK 版本为 1.7 等),插件的配置方式可参考官网的说明。官网插件配置说明

8 maven 常用插件

  • maven-clean-plugin
    作用:这个插件的主要作用就是清理构建目录下得全部内容,构建目录默认是target。

	maven-clean-plugin
	3.1.0
	
		
			auto-clean
			initialize
			
				clean
			
		
	

  • maven-compiler-plugin
    作用:设置maven编译的jdk版本,maven3默认用jdk1.5,maven2默认用jdk1.3

    org.apache.maven.plugins
    maven-compiler-plugin
    3.1
    
        
        1.8
        
        1.8
        
        UTF-8
        
        true
    

  • maven-jar-plugin
    作用:打包jar文件时,配置manifest文件,加入lib包的jar依赖

    org.apache.maven.plugins
    maven-jar-plugin
    3.3.0
    
        
        
            
            
            
            
            
            
            
            
                
                
                
                
                
                
                
                
                
                
                
                
                
                
                
                
            
            
            
                value
            
            
            
            
                
                    
                    
                        value
                    
                
            
            
        
        
        
            
        
        
        
            
        
    

  • maven-dependency-plugin
    作用:自动拷贝依赖的jar包到target目录

    org.apache.maven.plugins
    maven-dependency-plugin
    2.6
    
        
            copy-dependencies
            compile
            
                copy-dependencies
            
            
                
                ${project.build.directory}/lib
                
                false
                
                true
            
        
    

  • maven-antrun-plugin
    作用:可以在Maven执行时,额外执行Ant脚本。

    maven-antrun-plugin
    3.0.0
    
        
            
                
            
            
                
                    
                
            
            
                run
            
        
    

  • maven-source-plugin
    作用:打包源码
    注意:在多项目构建中,将source-plugin置于顶层或parent的pom中并不会发挥作用,必须置于具体项目的pom中。

    org.apache.maven.plugins
    maven-source-plugin
    
        
            attach-sources
            
                jar
            
        
    

  • maven-resource-plugin
    作用:该插件处理项目的资源文件拷贝到输出目录。可以分别处理 main resources 和 test resources。

    org.apache.maven.plugins
    maven-resources-plugin
    3.0.1
    
        UTF-8
     

  • maven-assembly-plugin
    作用:该插件允许用户整合项目的输出,包括依赖、模块、网站文档和其他文档到一个单独的文档,即可用定制化打包。
    创建的文档格式包括:zip,tar,tar.gz(tgz),gar.bz2(tbgz2),jar,dir,war 等等。四种预定义的描述器可用:bin,jar-with-dependencies,src,project。

	maven-assembly-plugin
	3.0.0
	
		
		jar-with-dependencies
		
	
	
		
			make-assembly 
			package 
			
				single
			
		
	

9 参考资料(感谢)

maven-dependency-plugin插件的使用