书评 : 《Introducing Maven》
我个人比较喜欢轻薄的技术书,这本《Introducing Maven》,便是符合我对轻便要求的一本书。
每当我要了解一项新技术,以前很多次一头扎进冗长的文档,或者一头扎进"权威指南",很容易就失去了耐心。
我觉得适合入门的书或者文档应该是简短概括的,面面俱全但又点到为止。现在有些项目的主页上的文档除了全量版的,还有一些类似于概括性的入门级文档,这对开发者来说,是个福音。
这本《Introducing Maven》共8章,涵盖了以下内容:
第一章先简短介绍了maven这项技术为何出现,以及它的历史。然后分析了maven能带来的种种好处:
- 统一的项目目录结构
- 只需告诉maven "what you need"
- 插件化(plugin)
- 项目结构模板(archetype)
在maven的世界中
约定大于配置(Convention over Configuration, CoC)
使用maven时
有了maven,只需要说"what",而不用去想"how"
这本书每章简单易读,每一章都相应伴随着一个简单例子。这本书并不涉及特定IDE上,maven的使用方法。
每个使用例子都是以命令行方式演示,而这也是最容易了解其本质的方式。IDE上集成的一些功能,实际上也是执行maven提供的这些命令。
本书在告诉我们如何安装配置maven时,也告诉了我们一个特别重要的文件settings.xml,里面各个配置项的意义。
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0
http://maven.apache.org/xsd/settings-1.0.0.xsd">
<localRepository/>
<interactiveMode/>
<usePluginRegistry/>
<offline/>
<pluginGroups/>
<servers/>
<mirrors/>
<proxies/>
<profiles/>
<activeProfiles/>
</settings>
我公司使用maven来做打包,发布,依赖处理时,搭建了公司内基于nexus的private repository。通过阅读本章,再去查看自己电脑上的settings.xml文件,便能明白以前一些还很模糊的东西。以上各个配置项的意义如下所示 :
maven如何帮我们管理你所要依赖的Jar包。一个通用的maven体系通常如下图所示 :
但对于企业来说,除了考虑安全的因素,还要考虑协作的问题,因此企业的maven体系通常如下图所示 :
增加了本地私有仓库,在这个基础上,可以指定或者过滤筛选其它的外部仓库。
maven还能帮你解决传播性依赖的问题,比如我们需要依赖commons-digester3项目,作为配置加载的工具,但其却依赖了其它jar包。maven可以让我们不用手工去下载所有这些依赖的jar包,它能帮我们理清多级依赖。并且还能解决jar包的版本冲突:
解决版本冲突时,如果该版本的jar包是受到直接依赖的,则选择这个版本的jar包。如果不是直接依赖的,这按"先来后到"的顺序,选择它最先检测到的一个版本。
这本书涵盖了使用maven需要考虑到的方方面面,却又点到为止,除了上述,这本书还告诉我们pom.xml中各个配置项的意义。以及如何从源码构建项目。
讲解了Maven生命周期各个阶段与pluging,以及goals的关系,一张图让人一目了然:
也介绍了如何开发插件,如何从已有的项目结构生成archetype,以及如何使用maven应对多模块的项目。都是一些非常实用的功能。
最后提到了如何使用maven生成项目的主页网页,以及各种文档,包括JavaDoc,单元测试报告,代码覆盖率,findBugs报告等,以及如何发布项目。
by the way,apress出版社出版的黑皮书都很不错。