Apache Ant使用过程的总结

简介:

最近频繁的做Web项目的部署,开发机是Windows系统,服务器在RedHat上,多次使用SecureCRT工具后,决定直接使用Ant部署工具做这件事,同时遇到一个问题:Java程序程序中调用Ant API或者执行Ant 命令。


     本文算是对近来使用Ant的一些总结和问题记录。


     1.Ant 是什么?

 Apache Ant是一个将软件编译、测试、部署等步骤联系在一起加以自动化的一个工具,大多用于Java环境中的软件开发。

     2.Maven是什么?

       Maven是基于项目对象模型(POM),通过一定的描述信息来管理项目。

3.Ant vs Maven?

       理解Ant和Maven的不同之处和各自的发展会有助于我们做更好的选择。

http://ant.apache.org/

http://maven.apache.org/

       Ant 和 Maven同属于Aapche基金会下的项目,Maven是在借鉴Ant的优秀之处更上一层楼的面向软件项目管理工具。



       下面的Ant配置文件做一个Web项目的编译,打包,部署,清理工作。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
<? xml  version = "1.0"  encoding = "UTF-8" ?>
< project  name = "test"  basedir = "."  default = "makewar" >
     <!--部署目标路径,需要根据实际情况设置-->
     < property  name = "webapp"  location = "D:\__dev\apache-tomcat-6.0.37\webapps"  />
     < property  name = "warname"  value = "ROOT.war"  />
     <!-- 引用的外部Jar包,需要根据实际情况设置 -->
     < property  name = "libs"  location = "\libs\bin"  />
     < property  name = "debuglevel"  value = "source,lines,vars"  />
     <!--eclipse是WebRoot,Myeclipse是WebContent,需要根据实际情况设置-->
     < property  name = "webroot"  value = "${basedir}/WebContent"  />
     < property  name = "sources"  value = "${basedir}/src"  />
     <!--输出内容路径设置-->
     < property  name = "dest"  value = "${basedir}/dest"  />
     < property  name = "classes"  value = "${basedir}/build/classes"  />
     < path  id = "classpath"  description = "jar包路径" >
         < fileset  dir = "${libs}" >
             < include  name = "*.jar"  />
         </ fileset >
     </ path >
     < target  name = "init"  description = "初始化构建目录结构和拷贝文件" >
         < mkdir  dir = "${dest}"  />
         < mkdir  dir = "${classes}"  />
         < copy  todir = "${dest}" >
             < fileset  dir = "${webroot}" >
                 < include  name = "WEB-INF/**"  />
                 < include  name = "**"  />
             </ fileset >
         </ copy >
         < copy  todir = "${classes}"  verbose = "true" >
             < fileset  dir = "${sources}" >
                 < include  name = "*.xml"  />
                 < include  name = "*.Properties"  />
                 < include  name = "*.properties"  />
             </ fileset >
         </ copy >
         < copy  todir = "${classes}/libs"  verbose = "true" >
             < fileset  dir = "${libs}" >
                 < include  name = "*.jar" />
             </ fileset >
         </ copy >
     </ target >
     < target  name = "complie"  depends = "init"  description = "编译" >
         < javac  srcdir = "${sources}"  destdir = "${classes}"  encoding = "utf-8"  classpathref = "classpath" >
         </ javac >
     </ target >
     < target  name = "makewar"  depends = "complie"  description = "打包部署" >
         < war  warfile = "${basedir}/${warname}"  webxml = "${dest}/WEB-INF/web.xml" >
             < lib  dir = "${libs}" >
                 < include  name = "*.*"  />
             </ lib >
             < classes  dir = "${classes}"  />
             < fileset  dir = "${dest}"  />
         </ war >
     </ target >
     < target  name = "clean"  description = "清理" >
         < delete  dir = "${dest}" >
         </ delete >
         < delete  dir = "${classes}" >
         </ delete >
         < delete  file = "${basedir}/${warname}"  />
     </ target >
     < target  name = "move"  description = "部署war包到tomcat的webapp下" >
         < copy  todir = "${webapp}"  file = "${basedir}/${warname}"  overwrite = "yes" >
         </ copy >
     </ target >
     < target  name = "cleanweb"  description = "清理tomcat的webapp下的工程" >
         < delete  dir = "${webapp}/${ant.project.name}"  includeemptydirs = "true" >
         </ delete >
         < delete  file = "${webapp}/${warname}" >
         </ delete >
     </ target >
</ project >


    1.如何搭建Ant呢?

     Ant是Apache基金会的项目,继承这一贯的命令模式,配置ANT_HOME,至于怎么配置和JAVA_HOME配置一样,网上好多时候要说配置CLASSPATH之类的路径,其实在JDK1.6以后是不需要的

     命令行中:

     >ant

        Buildfile: build.xml does not exist!
        Build failed 

      表明Ant环境搭建成功。

      命令行中 :  ant -help查看ant命令的详细帮助信息。

    2.关于Ant的build文件

      Ant的build文件大致配置如左: 工程——>目标——>任务

     从上面的配置信息中可以看出,target中包含着delete,copy,war等任务。

   3.关于Ant的build文件编写

     如何编写build文件呢?project,target,task的各个属性,都写什么内容呢?

     一下N种途径:

     使用支持Ant的IDE,具有提示功能;(最常用)

     使用Ant的Build文件的模版改动;(适合已经有成功部署能案例支持)

     使用Ant的帮助文档,Ant帮助文档中给出了详细的列表,Ant is written in Java.因而我们在使用Ant提供的各种任务工具都离不开Java程序的支持,因此通过API可以查看到各种任务需要的属性等信息。(不断挖掘Ant强大的工具能力)

   4.关于Ant的任务

      在Ant的帮助文档中有一个List of Task和 Library Dependencies,前者提供了Ant为我们提供的任务集,后者对前者使用时应该具备的一些条件做描述,比如:要执行Ant的email任务,我们知道Java发送邮件需要mail.jar的支持,所以在执行该任务的时候需要在运行环境中添加mail.jar包。

     通过命令查看任务依赖环境:ant -diagnostics 将会有一个详细的 Ant diagnostics report。

012459825.png

    通过diagnostics报告信息可以看出在我的机器上要运行scp任务的时候需要依赖:com.jcraft.jsch.Logger类,该类来自jsch.jar 0.1.50,注意不同的Ant版本可能对应的依赖jar版本不同,这时候就应该查询用户指南。

    关于Ant任务的第三方依赖jar的相关信息获取的方式,个人有个比较好的体验先baidu,然后google这样会很快解决问题,baidu提供了一些中文用户的一些信息,google则提供英文信息更多些,了解一些所以然然后去官网查看或者源代码库才不至于一头雾水。

  5.ant命令

    ant的命令提供的各种执行build的参数,比如:-h(查看命令帮助), -version(查看Ant版本),-p(查看执行Build的工程信息),-lib(通过参数的放置添加依赖的jar路径) 等

  6.Ant工具学习

    使用Ant工具来帮助我们自动化的完成项目的编译,打包,部署,通过用户手册和IDE的帮助这些任务能完成。至于学习Ant,通过个人体会,长时间不用了或者采用3中的模版方式来使用久而久之会使Ant在我们心目中之能沦为一个简单的工具。

   完成我们开发工程需要上面的一些方式,途径就可以解决我们的问题,帮助我们完成工程的自动化构建。   



本文转自 secondriver 51CTO博客,原文链接:http://blog.51cto.com/aiilive/1346266,如需转载请自行联系原作者




j_0001.gif多想,多用,多发现发挥Ant的强力功效:

  •     通过了解AntAPI扩展Ant功能;

  •     多尝试一些不常用的命令或者参数;

  •     多思考把Ant和Java开发紧密联系在一起。


相关文章
|
分布式计算 Hadoop 程序员
Apache Hadoop 启动报错:masternode:ssh: connect to host master port 22: Connection timed out 总结
Apache Hadoop 启动报错:masternode:ssh: connect to host master port 22: Connection timed out 总结
451 0
Apache Hadoop 启动报错:masternode:ssh: connect to host master port 22: Connection timed out 总结
|
安全 Apache 数据安全/隐私保护
|
XML Java Apache
【Apache Ant】ANT解析以及ANT在myEclipse中的使用
【Apache Ant】ANT解析以及ANT在myEclipse中的使用
287 0
【Apache Ant】ANT解析以及ANT在myEclipse中的使用
|
SQL 存储 大数据
Apache Hive--DDL--创建表--分桶表总结&amp;分桶表好处| 学习笔记
快速学习 Apache Hive--DDL--创建表--分桶表总结&amp;分桶表好处
167 0
Apache Hive--DDL--创建表--分桶表总结&amp;分桶表好处| 学习笔记
|
Apache
Apache Plusar社区资源总结
Apache Plusar社区资源总结
114 0
|
存储 Kubernetes Dubbo
架构师成长系列 | 从 2019 到 2020,Apache Dubbo 年度回顾与总结
Apache Dubbo 是一款开源的 RPC 框架,其提供了简单易用、高性能的 RPC 能力、灵活可控的扩展、强大的服务治理,目前已有 Java、Go、JS、Python 等多个语言支持;并且已经悄然衍进为 Cloud Native 基础设施。这一切成就都离不开 Dubbo 社区的建设,本文将由 Apache Dubbo PMC 刘军来介绍 Dubbo 社区在过去的一年取得的成绩及未来 Dubbo 社区的发展新规划。
架构师成长系列 | 从 2019 到 2020,Apache Dubbo 年度回顾与总结
|
敏捷开发 缓存 分布式计算
Apache架构师总结的30条设计原则
云栖号资讯:【点击查看更多行业资讯】在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! 【编者的话】本文作者叫Srinath,是一位科学家,软件架构师,也是一名在分布式系统上工作的程序员。
|
Java Apache 数据格式

推荐镜像

更多