Maven3初窥

Maven3的开发已经完成大半,本周末将发布alpha-3(Twitter @jvanzyl),而Nexus已经开始使用Maven3进行构建,于是我也开始使用Maven3。

 

http://svn.apache.org/repos/asf/maven/maven-3/trunk 签出最新的maven3代码,然后使用maven2进行build,build完毕之后,便能得到Maven安装文件apache-maven/target/apache-maven-3.0-SNAPSHOT-bin.zip ,接着升级本地的maven2至maven3,检查安装如下:

控制台输出
juven@juven-ubuntu:~$ mvn -v
Apache Maven 3.0-SNAPSHOT (r833360; 2009-11-06 19:53:14+0800)
Java version: 1.6.0_11
Java home: /usr/local/jdk1.6.0_11/jre
Default locale: en_US, platform encoding: UTF-8
OS name: "linux" version: "2.6.27-7-generic" arch: "i386" Family: "unix"
 

Maven本身提倡的一个原则是,不要使用任何外部的SNAPSHOT依赖,这里我却在使用SNAPSHOT的Maven,未免有些讽刺的意味,因此难免有些担心。不过,build完Nexus之后,我的担心就消除了,使用maven3 build Nexus没有出现任何问题。而且从build输出我就发现maven3的一大优点,build输出更加明了:

Maven3输出
[INFO] Building Nexus (API) 1.4.1-SNAPSHOT
[INFO] ------------------------------------------------------------------------
[INFO]
[INFO] --- maven-clean-plugin:2.2:clean (default-clean) @ nexus-api ---
[INFO] Deleting directory /home/juven/workspaces/ws-nexus/nexus/nexus-api/target
[INFO]
[INFO] --- maven-resources-plugin:2.4:resources (default-resources) @ nexus-api ---
[WARNING] Using platform encoding (UTF-8 actually) to copy filtered resources, i.e. build is platform dependent!
[INFO] skip non existing resourceDirectory /home/juven/workspaces/ws-nexus/nexus/nexus-api/src/main/resources
[INFO]
[INFO] --- maven-compiler-plugin:2.0.2:compile (default-compile) @ nexus-api ---
[INFO] Compiling 191 source files to /home/juven/workspaces/ws-nexus/nexus/nexus-api/target/classes
[INFO]
[INFO] --- plexus-component-metadata:1.2.1:generate-metadata (process-classes) @ nexus-api ---
[INFO] Discovered 1 component descriptors(s)
[INFO]
[INFO] --- maven-resources-plugin:2.4:testResources (default-testResources) @ nexus-api ---
[WARNING] Using platform encoding (UTF-8 actually) to copy filtered resources, i.e. build is platform dependent!
[INFO] skip non existing resourceDirectory /home/juven/workspaces/ws-nexus/nexus/nexus-api/src/test/resources
[INFO]
[INFO] --- maven-compiler-plugin:2.0.2:testCompile (default-testCompile) @ nexus-api ---
[INFO] Nothing to compile - all classes are up to date
[INFO]
[INFO] --- plexus-component-metadata:1.2.1:generate-test-metadata (process-test-classes) @ nexus-api ---

比较下Maven2的输出:

Maven2输出
[INFO] Building Spice Timeline
[INFO] task-segment: [clean, install]
[INFO] ------------------------------------------------------------------------
[INFO] [clean:clean]
[INFO] Deleting directory D:\demo\spice-timeline\target
[INFO] [resources:resources]
[INFO] Using default encoding to copy filtered resources.
[INFO] [compiler:compile]
[INFO] Compiling 14 source files to D:\demo\spice-timeline\target\classes
[INFO] [plexus-component-metadata:generate-metadata {execution: process-classes}]
[INFO] Discovered 3 component descriptors(s)
[INFO] [resources:testResources]
[INFO] Using default encoding to copy filtered resources.
[INFO] [compiler:testCompile]
[INFO] Compiling 4 source files to D:\demo\spice-timeline\target\test-classes
[INFO] [plexus-component-metadata:generate-test-metadata {execution: process-test-classes}]
[INFO] [surefire:test]
[INFO] Surefire report directory: D:\demo\spice-timeline\target\surefire-reports

Maven3的输出中,正在运行的插件,以及build所处的项目信息更加清晰。使用缩进来标示插件,更容易找到各个插件的运行情况,而增加@ nexus-api这样的信息,就能在一个多模块构建中更方便的看到当前所build的项目。

 

目前,几乎没有什么关于Maven3的文档,不过有两篇博客和一个wiki提供了很多有用的信息:

Maven 3.0 technology preview: Interview with Benjamin Bentmann

Maven 3.x: Paving the desire lines — Part One

Maven 3.x Compatibility Notes

 

基于以上的信息以及我自己简单的使用经验,这里有一个简单的总结,归纳Maven3主要的目的和特性:

  • 重构和清理代码库
    Maven3减少了代码中模块的数量,并基于大量的集成测试,对Maven核心进行重大的重构。一方面方便修复一些之前由于Maven2架构问题无法修复的bug,另一方面,更简单优雅的代码也容易吸引开源爱好者的加入及贡献。
  • 完全兼容Maven2
    Maven3不会破坏现存的Maven2构建,为此Maven团队已经开发了500多个集成测试以覆盖各种情况,到GA版本的时候,这个数字会达到600。
  • 改进多模块构建
    Maven2的多模块构建中,模块A必须install之后才能被模块B使用,Maven3消除了这一限制,比如说模块A编译之后,模块B就能直接使用其输出class。
  • 改进插件版本解析机制
    Maven2的一大问题是用户可以不指定插件版本就能直接使用插件,而Maven会自动解析最新的插件版本(可能是SNAPSHOT),这造成了build的不可预知性,有时会因为某个插件版本的变化而导致build失败。自maven 2.0.9开始所有核心插件明确指定了版本,但这还不够,在Maven3中,如果发现有未指定版本的插件,Maven会发出警告,此外,如果你忽略警告,Maven也只会解析最新的RELEASE版本,而不会再使用SNAPSHOT。这样,既保持了对Maven2的兼容,也在最大程度上避免因插件版本不稳定引起的build失败。
  • 从核心分离site和reporting模块
    Maven2的核心生命周期包含了site,而site又与Doxia绑定,maven3将site以及reporting分离,通过插件,当前的maven2 site仍然可以使用,而且,使用非Doxia格式的site也成为了可能。
  • 更好的支持嵌入环境如CI和IDE
    Maven2缺乏对嵌入环境的考虑,maven3基于一些集成的经验如m2eclipse, hudson,对这一点进行了改进,因此,将来在IDE和CI服务器,或者Nexus中,集成Maven会更加方便。

最后,我将持续对Maven3进行关注,并在博客中更新相关信息。

你可能感兴趣的:(apache,maven,linux,SVN,ubuntu)