《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\test\runtime,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定义各个环境
- 在代码的配置文件中定义变量$
- 在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与微服务构建》,看了后,实在无语,衬托出许晓斌的很好
- 几年后再次认真阅读,感受不同。揭开了几年里的一些积累的疑惑