《Maven实战》(许晓斌)导读(读书笔记&第二次读后感)

第一章 Maven简介

Maven是构建工具,但同时还是jar包管理工具、项目信息管理工具
与Make、Ant比较,更为先进

第二章 Maven的安装和配置

Windows和Unix上安装都很简单,下载压缩包解压,再配置环境变量即可
jar包默认在~./m2目录
可以使用eclipse的maven插件m2eclipse,但不要使用eclipse内嵌的maven
使用maven时如内存不够等错误,可通过设置MAVEN_OPS环境变量设置java内存大小
.m2下的settings.xml是用户的,maven的conf下settings.xml是全局的

第三章Maven使用入门

入门

编写pom.xml、写java主代码、写测试代码就可以使用maven打包运行
命令mvn archetype:generate生成项目骨架
也可使用m2eclipse导入或者生成maven项目

POM

project是根元素
modelVersion对于maven2和3,必须是4.0.0
groupId、artifactId、version是基本坐标(artifact是人工制品的意思)
groupId是项目属于哪个组
artifactId是项目或者子项目或者模块
推荐每个maven声明name,方便交流

maven编译

mvn clean compile
clean是清理target,compile是编译

maven测试

scope设置为test,主代码import这个jar会报错
mvn clean test
这时应该会报错。因为测试一般用到junit,需要jdk1.5以上,而maven的compile插件由于历史原因默认1.3
pom.xml增加build-plugins-plugin,maven-compiler-plugin的source和target指定为1.5

打包运行

打包mvn clean package
打包默认是jar
安装mvn clean install
install会安装到本地的仓库
默认的jar不能执行main方法,因为mainfest里没有。设置pom,plugin,maven-shade-plugin,mainclass设定为你的class,再看META-INF/MANIFEST.MF

第4章 背景案例

主要uml设计、java包说明等,就3页

第5章 坐标和依赖

这一章非常重要

maven坐标还有classifier,主要是附属构件,比如一个是jdk1.4的,一个是jdk1.5的。不能定义,只能插件生成
maven依赖里有type,默认是jar,对应项目的packaging,一般不用声明
依赖范围有5个。compile estuntime,provided是编译测试有效,运行无效,如servlet-api,因为容器已提供。system制定本机系统的路径,不通过maven仓库,不可移植,谨慎使用还有一个import,对编译、测试、运行不起作用。

传递性依赖

pom里引入了a.jar,则a用到的jar都会自动引入
自动引入是看中央仓库里这个jar平行的pom文件
当然a用到了b.jar,那b用到jar也会传递,一直传递下去
依赖范围对依赖的传递有影响

依赖调解

依赖了同一个jar,则路径最近者优先
路径一样则第一声明者优先
optional为true可选依赖,不会被传递

最佳实践

可排除一些传递的依赖
最好使用properties定义统一的jar版本
mvn dependency:list依赖树(大家更常用tree)
mvn dependency:analyze分析依赖,项目用到但没声明的依赖,还有声明了但没用到的依赖(不能随便删除,要分析)

第六章 仓库
第七章 生命周期和插件
略。

第八章 聚合与继承

本章也非常重要
聚合在aggregator(名字随便定)模块设置modules-module,aggregator一般放在上层
继承在子项目里配置relativePath,比如../xxx-parent/pom.xml
继承用到dependencyManagement
继承后以来的jar可以不写version,父那里写了,依赖范围也是
import在dependencyManagement下才有效,配了后把某项目的依赖全部弄过来
如果不用dependencyManagement,父的全部jar子都必须继承,这样不太推荐
聚合为了方便构建;继承为了消除重复配置
父知道聚合了谁,子不知道被谁聚合;子知道继承了谁,父不知道被谁继承
约定由于配置,convention over confiuration
所有的pom都是默认继承超级pom,超级pom在lib的model-build的jar里
反应堆reactor,模块构建顺序,可设置,通过修改配置和命令

第九章 使用nexus创建私服
第十章 使用maven进行测试
第十一章 使用Hudson进行持续集成

几年前已搭建过nexus,使用过jenkins、cargo,略。

第十二章 使用maven构建web应用

web的目录结构src-main-webapp
默认是jar,需要packaging:war
制定war包名字:build-finalName

第十三章 版本管理
略。产品需要版本多一些。项目较少。svn专人管理。

第十四章 灵活的构建

开发环境、测试环境、生产环境的多环境构建很重要,一般都要用到
通过profiles定义各个环境
在代码的配置文件中定义变量${aaa}
在pom里制定aaa在各个环境中的值
在pom里资源过滤
打包时命令加-P,mvn clean install -Pdev,假设开发环境在pom的profile里id定义为dev
可以激活多个profile,mvn clean install -Pdev-x,dev-y
可以根据属性激活,mvn clean install -Pdev=x。前提需要profile里配置name和value
可以设置默认激活,可以根据文件是否存在来激活
profile除了pom,也可以在settings。xml配置。
资源过滤除了可以过滤resource,也可以过滤webapp里,用webResources

第十五章 生成项目站点
第十六章 m2eclipse
第十七章 编写maven插件
第十八章 Archetype
附录
略。这些不太常用,或者比较简单不太重要。

我的感想

不足:

没有列出maven推荐的全部目录,比如filters等
Hudson,也就是jenkins章节过于简单
多环境配置profiles章节不够完整,最为常用的目录配置没有讲,只讲了变量配置
好像没有介绍-X等debug命令项,和最一些报错的注意事项(也许我读漏了)
eclipse插件我遇到过蛮多问题,书里没有详细解说,或者作者喜欢命令行
对老项目的迁移也没怎么涉及

总的来说,还是很优秀的书。因为:

就这一本,没别的
最近买了方志朋的《深入理解spring cloud与微服务构建》,看了后,实在无语,衬托出许晓斌的很好
几年后再次认真阅读,感受不同。揭开了几年里的一些积累的疑惑

Published by

风君子

独自遨游何稽首 揭天掀地慰生平

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注