MAVEN和ANT,Svn的讨论

来源:互联网 发布:网络写手哪个网站好 编辑:程序博客网 时间:2024/06/02 22:21


各抒己见:MAVEN比ANT好在哪里

来征求大家的意见,现将讨论内容整理如下:

原帖内容:

以前一直用Ant,最近准备上Sonar这个开源的代码质量管理平台,跟MAVEN关系很大, 
准备看看,第一印象是: 
哇! 
好复杂! 

同时用过两种工具的同仁们,希望不吝赐教,讨论一下: 

1、MAVEN是真复杂,还是只是看起来复杂? 
2、MAVEN比ANT好在哪里? 

谢谢!

daisycool 首先结合自己的实践,给出了非常中肯的意见:

我大部分的工作都是用maven来做的,少量是ant,说说自己的感想。 

maven搭建工程很快,不需要特殊外挂什么的,直接就可以上手工作;而ant起步就比较麻烦,需要写一大堆东西。也就是说,maven预设了一些方便的功能,而ant只能自己写。 

maven要想修改默认设定比较麻烦,maven1还好点,是用maven.xml来控制,maven2全部集成到plugin里,麻烦;ant全都在build.xml里,创建的时候虽然工作量大,但修改起来就比较方便。 

maven对于第三方库文件支持比较好,自动下载存储,还能添加到IDE的工作路径里,对于库文件的管理和团队开发帮助都很大。这个有用的功能导致了工程 的移植特别方便,不用进行特殊配置,只要运行maven就可以自动配置好工程的开发环境;ant在这方面没发现有什么特长,工程移植到其他电脑上时配置和 调试很麻烦。 

maven外挂丰富,降低工作繁重程度;ant还是基于手写。比如maven和ant都有自动封装打包的功能,不过maven有许多现成的外挂,添加进pom.xml就可以使用,方便,相比之下ant还是手工劳动程度比较大。 

maven和ant学习起来都有一个过程,不过ant比maven直观些,毕竟XML一看就能明白,而maven的功能都是基于外挂,所以不太好理解,不过一旦理解maven的原理之后也很容易上手。 

其实maven和ant干的活和能实现的东西都差不多,就看你喜欢用哪个。 

个人的一点浅见,供LZ参考。

然后xyz20003 连发三篇,阐明了自己的看法:

探讨一二,也就是说以前写的不管用咯,唉,好严格。 

我还是觉得,如果上层推不动,maven2这种纯构建的东东就用不起来。你说让一个刚毕业的,连软件开发流程的同志搞maven2,有点儿难哦, 

至少他要知道maven2是做什么的,每个phase都是用来做什么的,为什么test要放在package前面,为什么要有integration- test,为什么要区分version进行依赖。为什么目录结构区分main和test,下级目录为什么又要保持java和resource分开,为什么 要统一将生成的文件放到target下。 

如果了解了这些,可以用ant写一个功能与maven2相近的脚本出来,虽然build.xml会稍大一些。不过灵活完全可以定制。 

不是说ant不好,你看spring都是用ant编译的,你看他们写了多少脚本? 

最后,我的感觉呢,是这样的: 

你如果自己写个小工具玩玩,ant既灵活,运行又快。 
如果这个东西需要与人分享,或者希望达到一种团队内部的标准,那么用maven2吧,它就是标准化的一个范例。你看多少apache项目都在用maven2,学会maven2的好处就是可以很快看懂这些项目的结构,用最快的速度把一个项目构建起来,减少沟通的壁垒。 

所以,你如果在企业内部,用不用maven2都看你自己的爱好了,如果你学习开源,那还是赶快学学吧。

ant现在发布包,大概18m 
maven2的发布包,大概2.8m 

在下本地的repo大概1G,主要因为之前的version太多了。 

但是每次你要为ant添加一个功能,都要自己去找lib。 
maven下直接配置一个,它就自己去下载了。 

又有人说,我的项目都是ssh,我直接copy就行了。 

这点我真比不了,google code上放个开源项目,我如果把lib都放上去,每个项目估计都上百m,maven2的话,这些东西至少不用放到svn里去了。 

还是那句话,企业内部是个很狭小的圈子,maven2虽然可以保证一部分标准化,但是完全没有开源那么大的利益。所以自己估量着办吧。你要是能把maven2的开发过程搞清楚,自己也可以用ant写一套这样的脚本了。插件自己配,依赖自己找,一样的。 

但是为什么我们要学maven2,因为不重复造轮子,别人已经写好了的。

又看了一下LZ的问题,原来是因为sonar。 

这就是企业被开源绑架的一个例子,你本来不想学这个东西,但是开源已经在广泛使用了,君不见hudson也对maven2提供了良好的支持?这时要么选择放弃,要么选择妥协。 

结果就是,当俺们需要免费品尝别人提供的大餐时,就需要接受别人已经制定好的标准咯。

miaoliujun 重点阐述了对依赖问题的看法:

公司管理用MAVEN比较适合点,个人做做私活可以用ANT 
当然,如果你对MAVEN比较熟悉,有自己的成熟的模板可以套用,无论做什么样的项目都可以考虑用MAVEN。ANT其实也是可以的。 
MAVEN不仅仅是ANT的一个升级,它有很多项目管理上的一些帮助。 

前面有楼层说过不上网依赖包的问题,这个我是这么认为的,依赖包最好是到公用的地方去下载,这样保证这个依赖包的合法性,公司里由于人员的走动等有些 jar包可能是没有版本信息,有些JAR包可能都被修改过的,混乱后也不利于后面的人来维护;如果不可以上网,有两种解决方法:1,在第一次编译的时候进 行连网下载,并将此包建立成内网的库映象;2,你确保是正确的版本,copy到内网的库映象中去。

至于复杂性的问题,我承认要理解一个理念是很复杂,但一个公司只需要一个人去理解,其他人不需要全部理解,知道怎么做即可。

xyz20003 对于miaoliujun 提出来的复杂度问题,又做了阐释:

同上所述,一个公司里最多有一两个人会配置maven2即可,剩下人只需要从svn上checkout,然后执行对应的goal即可。 

实际上我还是感觉maven2这类构建工具应该是项目管理,甚至项目架构人员使用的,楼主的“逆向软件团队管理方式”本意虽然不坏,只是类似让没有学习过任何内功心法的人直接去练乾坤大挪移,九死一生啊。 

实际上,如果公司拥有内部repo,maven2就可以实现插件共享,可以内部编写的plugin直接deploy到repo上,其他人通过maven2就可以直接配置使用了,这点上看,如果要用ant的话就没那么方便了。 

再者,maven2很容易让内部所有人强制使用相同的目录结构和开发流程,这也是很多开源支持maven2的原因,因为这些phase和顺序都钉死了,我们只要直接去调用就好了。 ant则太灵活了,你可以随便写,随便写的结果就是只有你自己能用。 

所以又是二则选择,是选择灵活,然后让跟别人互动搞得十分麻烦,还是接受限制,同时可以和其他人无缝整合? 

保证自我,还是保证群体,这是个问题。

最后是我经过几天学习以后的粗浅看法:

抽时间看了一下MAVEN官方的文档,对它总算是有一些基本的概念了。 

从我目前了解的情况来看,使用MAVEN确实很规范, 
在便利性方面,比起ANT, 
有些地方方便多了,主要是因为其规范的目录结构以及规范的流程, 
这样就省的最简单的编译任务还要写脚本,而且用默认的目录结构也很好。 

但对于依赖的管理方面,个人感觉实在有些麻烦, 
目前还没有找到一次性把我已经有的lib加入依赖的方法, 
还需要一个个手工配置,真的很烦。 

也许maven认为这些工作是项目管理过程中保证项目质量的一个部分(所有的依赖都是显式声明的,比较精确?),
而且通常配置完毕后,各项目可以继承,倒也可以接受。 

继续研究,看还能不能简化工作量。

从复杂度来讲,MAVEN和ANT真不是一个级别的,带来的问题在某些情况下也相当严重,

我今天就碰到了下载一个插件失败而导致整个工程完全无法编译下去的情况。

像类似的问题,如果不是深入了解MAVEN,恐怕解决起来都相当棘手。

学习无止境,继续研究吧。

原创粉丝点击