`

Apache Maven和Apache Ant,你该选谁

阅读更多

 

Maven是什么?如何回答这个问题要看你怎么看这个问题。 绝大部分Maven用户都称Maven是一个"构建工具":一个用来把源代码构建成可发布的构件的工具。 构建工程师和项目经理会说Maven是一个更复杂的东西:一个项目管理工具。那么区别是什么? 像Ant这样的构建工具仅仅是关注预处理,编译,打包,测试和分发。

 

 

像 Maven 这样的一个项目管理工具提供了构建工具所提供功能的超集。 除了提供构建的功能,Maven还可以生成报告,生成Web站点,并且帮助推动工作团 队成员间的交流。

一个更正式的 Apache Maven1 的定义: Maven是一个项目管理工具,它包含了一个项目对象模型 (Project Object Model),一组标准集合,一个项目生命周期(ProjectLifecycle),一个依赖管理系统(Dependency Management System),和用来运行定义在生命周期阶段(phase)中插件(plugin)目标(goal)的逻辑。 当你使用Maven的时候,你用一个明确定义的项目对象模型来描述你的项目,然后 Maven 可以应用横切的逻辑,这些逻辑来自一组共享的(或者自定义的)插件。别让Maven是一个"项目管理"工具的事实吓跑你。如果你只是在找一个构建工具,Maven能做这个工作。

 

 

我们认识到许多组织必须在 Apache Ant 和 Apache Maven 之间做一个选择。本节我们对比一下这两个

工具:

 

Ant 在构建过程方面十分优秀,它是一个基于任务和依赖的构建系统。每个任务包含一

组由 XML 编码的指令。有 copy 任务和 javac 任务,以及 jar 任务。在你使用 Ant

的时候,你为 Ant 提供特定的指令以编译和打包你的输出。看下面的例子,一个简单

的 build.xml 文件:

<project name="my-project" default="dist" basedir=".">

<description>

simple example build file

</description>

<!-- set global properties for this build -->

<property name="src" location="src/main/java"/>

<property name="build" location="target/classes"/>

<property name="dist" location="target"/>

<target name="init">

<!-- Create the time stamp -->

<tstamp/>

<!-- Create the build directory structure used by compile -->

<mkdir dir="org.apache.maven.model.Build@d7e661"/>

</target>

<target name="compile" depends="init"

description="compile the source " >

<!-- Compile the java code from ${src} into org.apache.maven.model.Build@d7e661 <javac srcdir="${src}" destdir="org.apache.maven.model.Build@d7e661"/>

</target>

<target name="dist" depends="compile"

description="generate the distribution" >

<!-- Create the distribution directory -->

<mkdir dir="${dist}/lib"/>

<!-- Put everything in org.apache.maven.model.Build@d7e661 into the MyProject-${<jar jarfile="${dist}/lib/MyProject-${DSTAMP}.jar" basedir="org.apache.maven.model.</target>

<target name="clean"

description="clean up" >

<!-- Delete the org.apache.maven.model.Build@d7e661 and ${dist} directory trees <delete dir="org.apache.maven.model.Build@d7e661"/>

<delete dir="${dist}"/>

</target>

</project>

 

在这个简单的 Ant 例子中,你能看到,你需要明确的告诉 Ant 你想让它做什么。有

一个包含 javac 任务的编译目标用来将 src/main/java 的源码编译至 target/classes

目录。你必须明确告诉 Ant 你的源码在哪里,结果字节码你想存储在哪里,如何将这

些字节码打包成 JAR 文件。虽然最近有些进展以帮助 Ant 减少程序,但一个开发者对

Ant 的感受是用 XML 编写程序语言。

 

用 Maven 样例与之前的 Ant 样例做个比较。在 Maven 中,要从 Java 源码创建一个

JAR 文件,你只需要创建一个简单的 pom.xml,将你的源码放在 /usr/local/hudson/

hudson-home/jobs/maven-guide-zh-to-production/workspace/content-zh/src/main/

java ,然后从命令行运行 mvn install。下面的样例 Maven pom.xml 文件能完成和之

前 Ant 样例所做的同样的事情。

 

一个简单的 Maven pom.xml:

<project>

<modelVersion>4.0.0</modelVersion>

<groupId>org.sonatype.mavenbook</groupId>

<artifactId>my-project</artifactId>

<version>1.0</version>

</project>

 

这就是你 pom.xml 的全部。从命令行运行 mvn install 会处理资源文件,编译源代

码,运行单元测试,创建一个 JAR ,然后把这个 JAR 安装到本地仓库以为其它项目提

供重用性。不用做任何修改,你可以运行 mvn site ,然后在 target/site 目录找到

一个 index.html 文件,这个文件链接了 JavaDoc 和一些关于源代码的报告。

 

Maven 以插件的形式为一些一般的项目任务提供了内置的智能。如果你想要编写运行

单元测试,你需要做的只是编写测试然后放到 /usr/local/hudson/hudson-home/jobs/

maven-guide-zh-to-production/workspace/content-zh/src/test/java ,添加一个对

于 TestNG 或者 JUnit 的测试范围依赖,然后运行 mvn test 。如果你想要部署一个

web 应用而非 JAR ,你需要做的是改变你的项目类型为 war ,然后把你文档根目录置

为 /usr/local/hudson/hudson-home/jobs/maven-guide-zh-to-production/workspace/

content-zh/src/main/webapp 。

 

当然,你可以用 Ant 做这些事情,但是你将需要从零

开始写这些指令。使用 Ant ,你首先需要确定 JUnit JAR 文件应该放在哪里,然后你

需要创建一个包含这个 JUnit JAR 文件的 classpath ,然后告诉 Ant 它应该从哪里

去找测试源代码,编写一个目标来编译测试源代码为字节码,使用 JUnit 来执行单元

测试。

 

没有诸如 antlibs 和 lvy 等技术的支持(即使有了这些支持技术),Ant 给人感觉是

自定义的程序化构建。项目中一组高效的坚持约定的 Maven POM ,相对于 Ant 的配置

文件,只有很少的 XML 。Maven 的另一个优点是它依靠广泛公用的 Maven 插件。所有

人使用 Maven Surefire 插件来运行单元测试,如果有人添加了一些针对新的测试框

架的支持,你可以仅仅通过在你项目的 POM 中升级某个特定插件的版本来获得新的功

能。

 

使用 Maven 还是 Ant 的决定不是非此即彼的,Ant 在复杂的构建中还有它的位置。

如果你目前的构建包含一些高度自定义的过程,或者你已经写了一些 Ant 脚本通过一

种明确的方法完成一个明确的过程,而这种过程不适合 Maven 标准,你仍然可以在

Maven 中用这些脚本。作为一个 Maven 的核心插件, Ant 还是可用的。自定义的插件

可以用 Ant 来实现,Maven 项目可以配置成在生命周期中运行 Ant 的脚本。

 

说到这里,大家可以看出我这边儿更多的讲的是maven的优点而不是ant的(是不是很偏见,额.....)

所以该选择谁,大家也别指望我了,我是热烈的支持着maven的,但是我以为不管大家选择哪一个,

习惯哪一个,最好也把另外一个也研究一下,相互比较着学习,更能让你的思路清晰,更能让你在比较

中收获的更多,更全面。

 

ps:下篇文章,我打算写写maven的安装和基本的使用。

0
2
分享到:
评论
1 楼 zj304292653 2012-10-24  
最近可能使用maven,但是感觉很手生啊

相关推荐

    apache-maven-3.8.6-bin.zip

    与较旧的构建工具(例如Ant)(同样也是Apache项目)相比,Maven为开发人员提供了一种标准的方法来构建项目,对项目所包含的项目进行清晰的定义,发布项目信息的简便方法以及易于管理的项目项目库依赖项。...

    apache maven入门教程

    Apache Maven 是一个强大的项目管理工具,特别是在Java开发领域中,它替代了早期的ANT工具,提供了更为全面和便捷的项目构建和管理功能。Maven基于项目对象模型(Project Object Model,POM),能够自动化构建过程,...

    apache tomcat,maven,ant下载

    Apache Tomcat、Maven 和 Ant 是Java开发和部署中不可或缺的工具。让我们分别详细了解一下这三个重要组件及其在Java生态系统中的作用。 Apache Tomcat是一个开源的Servlet容器,它实现了Java Servlet和JavaServer ...

    apache-maven-3.8.5

    Maven项目对象模型(POM),可以通过一小段描述信息来管理项目的构建,报告和文档的项目管理工具软件。 Maven 除了以程序构建能力为特色之外,还提供高级项目管理工具。由于 Maven 的缺省构建规则有较高的可重用性,...

    java-maven-apache-ant-zip-2.3-jar包依赖

    在Java开发中,Maven和Apache Ant是两种广泛使用的构建工具,它们帮助开发者管理和构建项目。本文将深入探讨`com.ckfinder:apache-ant-zip:jar:2.3`这个特定的依赖,以及它在Maven和Ant中的作用。 首先,`...

    apache-ant-zip-2.3.jar.zip

    Apache Ant Zip 2.3.jar 是一个用于构建和管理Java项目的工具,它是Apache Ant库的一部分。Ant是一个由Apache软件基金会开发的任务驱动的构建系统,它使用XML来描述构建过程和依赖关系,使得构建过程可移植且易于...

    apache-maven-3.5.4.zip

    Maven项目对象模型(POM),可以通过一小段描述信息来管理项目的构建,报告和文档的项目管理工具软件。 Maven 除了以程序构建能力为特色之外,还提供高级项目管理工具。由于 Maven 的缺省构建规则有较高的可重用性,...

    apache-ant-1.6.0-bin.zip_ant 1_ant 1.6_ant 1.6.0_ant-1.6.0_apach

    在标题和描述中提到的 "apache-ant-1.6.0-bin.zip" 是Apache Ant 1.6.0版本的二进制发行包,这个版本在JSP(JavaServer Pages)开发中被广泛使用,提供了编译、打包、测试等自动化构建功能。 Ant 是由Apache软件...

    apache-maven-2.0.8.rar

    Apache Maven 是一个强大的项目管理和构建工具,主要用于Java应用程序的开发。在Java开发领域,Maven以其自动化构建、依赖管理和项目信息管理的能力而备受推崇。它通过一个统一的配置方式简化了项目的构建过程,并且...

    apache-maven-3.5.0.zip

    Maven项目对象模型(POM),可以通过一小段描述信息来管理项目的构建,报告和文档的项目管理工具软件。 Maven 除了以程序构建能力为特色之外,还提供高级项目管理工具。由于 Maven 的缺省构建规则有较高的可重用性,...

    ant-apache-oro.jar ant-apache-regexp.jar ant-apache-resolver.jar

    标题中的"ant-apache-oro.jar", "ant-apache-regexp.jar", 和 "ant-apache-resolver.jar" 是三个与Apache Ant相关的Java库文件。Apache Ant是一个由Apache软件基金会开发的Java构建工具,它广泛用于自动化Java项目的...

    maven-ant-tasks-2.1.3.zip

    在 Maven Ant Tasks 2.1.3 版本中,包含了主要的 jar 包 `maven-ant-tasks-2.1.3.jar`,它是该版本的核心组件,用于在 Ant 构建过程中调用 Maven 的功能。 使用 Maven Ant Tasks 的第一步是将其添加到 Ant 构建文件...

    apache-maven-3.2.5-src.zip

    Maven是基于项目对象模型(POM),可以通过一小段描述信息来管理项目的构建,报告和文档的软件项目管理工具。 Maven 除了以程序构建能力为特色之外,还提供高级项目管理工具。由于 Maven 的缺省构建规则有较高的可重用...

    apache官方ant-1.10.11版本压缩包

    这通常意味着解压缩后,你会得到一个名为"apache-ant-1.10.11"的目录,里面包含了Ant的所有组件,如bin目录(包含可执行脚本如`ant`和`ant.bat`),lib目录(包含Ant运行所需的jar文件),以及其他的文档、许可证和...

    maven compare to the ant

    本文将重点比较Maven和Ant两种流行的构建工具,分析它们的特点、优势以及应用场景。 #### Maven与Ant的基本介绍 1. **Apache Ant**: - **定义**:Ant是一款用Java编写的开源构建工具。 - **特点**:基于XML配置...

    apache-ant-1.9.16-bin.tar.gz

    Apache Ant 1.9.16 版本是该工具的一个稳定版本,它包含了对之前版本的改进和修复,确保了更好的兼容性和性能。这个版本可能包括对错误的修复,新功能的添加,以及对其他构建工具的接口优化。安装Apache Ant 1.9.16...

    apache-maven-3.1.1

    Maven 的出现是为了解决传统构建工具如Ant在大型项目中面临的复杂性问题,通过提供标准化的构建生命周期和插件系统,使得开发人员能够更加专注于编写代码,而不是构建过程。 标题“apache-maven-3.1.1”指的是Maven...

    apache-maven-3.3.9-bin

    在解压`apache-maven-3.3.9`后,你会看到以下主要文件和目录: - `bin`:包含Maven的可执行脚本,如`mvn`,用于在命令行中运行Maven。 - `conf`:包含Maven的配置文件,如`settings.xml`,用于设置本地仓库位置、...

    org.apache.tools.*需要的ant.jar包

    Apache Ant 是一个由Java编写的开源构建工具,它被广泛用于Java项目的构建、打包和部署。标题中的"org.apache.tools.*需要的ant.jar包"指的是Apache Ant的核心库,这个库包含了`org.apache.tools`包下的一系列类和...

Global site tag (gtag.js) - Google Analytics