《Maven实战》读书笔记
一、Maven使用入门
POM(Project Object Model,项目对象模型),定义了项目的基本信息,用于描述项目如何构建,声明项目依赖等等
二、坐标和依赖
1、何为Maven坐标
Maven坐标的元素包括groupId、artifactId、version、packaging、classifier
groupId:定义当前Maven项目隶属的实际项目
artifactId:该元素定义实际项目中的一个Maven项目(模块)
version:该元素定义Maven项目当前所处的版本
packaging:该元素定义Maven项目的打包方式
classifier:该元素用来定义构建输出的一些附属构建
2、依赖的配置
groupId、artifactId和version:依赖的基本坐标
type:依赖的类型
scope:以来的范围
optional:标记依赖是否可选
exclusions:用来排除传递性依赖
3、依赖范围
compile:编译依赖范围,默认依赖范围,对于编译、测试、运行三种classpath都有效
test:测试依赖范围(JUnit)
provided:已提供依赖范围(如容器依赖servlet-api)
runtime:运行时依赖范围(如JDBC驱动)
system:系统依赖范围(需显式指定依赖文件路径systemPath,用于Maven仓库之外的类库文件)
import:导入依赖范围
4、传递性依赖
当第二直接依赖的范围是complie的时候,传递性依赖的范围与第一直接依赖的范围一致;当第二直接依赖的范围是test的时候,依赖不会得以传递;当第二直接依赖的范围是provided的时候,只传递第一直接依赖范围也为provided的依赖,且传递依赖的范围同样为provided;当第二直接依赖的范围是runtime的时候,传递依赖的范围与第一直接依赖的范围一致,单compile例外,此时传递性依赖的范围为runtime
如果第一直接依赖、第二直接依赖和传递性依赖的范围一致,又叫范围传递性依赖
5、依赖调解
依赖调解第一原则:路径最近者优先,依赖关系最短的被解析使用
依赖调解第二原则;在依赖路径长度相等的前提下,在POM中依赖声明的顺序靠前的优先
6、可选依赖
只用于当前项目的依赖,不会被传递
<dependencies> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.10</version> <optional>true</optional> </dependency> <dependency> <groupId>postgresql</groupId> <artifactId>postgresql</artifactId> <version>8.4-701.jdbc3</version> <optional>true</optional> </dependency> </dependencies>
比如持久层工具包项目B,支持多种数据库,项目A在使用这个工具包的时候,需要显示声明对mysql-connector-java或project-b的依赖
7、排除依赖
传递性依赖会给项目隐式地引入很多依赖,有时候会带来问题。
例如,当前项目有一个第三方依赖,而这个第三方依赖由于某些原因依赖了另外一个类库的SNAPSHOT版本,那么这个SNAPSHOT就会成为当前项目的传递性依赖,而SNAPSHOT的不稳定性会直接影响到当前的项目。这时就需要排除掉该SNAPSHOT,并且在当前项目中声明该类库的某个正式发布的版本
还有一些情况,你可能想要替换某个传递性依赖,比如某个类库A不在中央仓库,而另一个类库B有对应的实现,就可以排除A再声明B
<dependencies> <dependency> <groupId>com.juvenxu.mvnbook</groupId> <artifactId>porject-b</artifactId> <version>1.0.0</version> <exclusions> <exclusion> <groupId>com.juvenxu.mvnbook</groupId> <artifactId>project-c</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>com.juvenxu.mvnbook</groupId> <artifactId>project-c</artifactId> <version>1.1.0</version> </dependency> </dependencies>
使用exclusions和子元素exclusion可以排除一个或者多个传递性依赖,声明exclusion的时候只需要groupId和artifactId,而不需要version
8、归类依赖
可以在唯一的地方定义版本,并且在dependency声明中引用这一版本
<properties> <springframework.version>2.5.6</springframework.version> </properties> <dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>${springframework.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-beans</artifactId> <version>${springframework.version}</version> </dependency> </dependencies>
三、仓库
1、仓库的分类
本地仓库和远程仓库,Maven会优先从本地仓库寻找构建,如果不存在就去远程仓库寻找,发现后下载到本地仓库再使用
远程仓库还分中央仓库、私服和其他公共库,中央仓库是Maven核心自带的远程仓库,包含了绝大部分开源的构件,私服是自己架设的私有的仓库服务器
Install插件的install目标将项目的构建输出文件安装到本地仓库
2、私服
节省自己的外网带宽
加速Maven构建
部署第三方构建
提高稳定性,增强控制
降低中央仓库的负荷
3、远程仓库
4、快照
版本号以SNAPSHOT作为后缀,可以多次发布,maven会自动在版本号最后加上时间戳,依赖这个包的项目只要mvn clean install-U就可以取到最新版本的包
5、镜像
相当于一个拦截器,把匹配到的发往中央仓库的请求转发到镜像仓库,一般配置阿里云的镜像可以显著提高下载速度,也有把私服作为镜像配置
镜像仓库是完全屏蔽被镜像仓库的,镜像仓库无法服务的时候,将无法下载构件
四、生命周期和插件
1、三套生命周期
clean生命周期
default生命周期
site生命周期
2、命令行与生命周期
$mvn clean
$mvn test
$mvn clean install
$mvn clean depoy
五、聚合与继承
1、聚合
为了一次构建多个项目,而不是到个个模块的目录下分别执行mvn命令
<modules> <module>acount-email</module> <module>acount-persist</module> </modules>
2、继承
为了消除重复的配置
<parent> <groupId></groupId> <artifactId></artifactId> <version></version> <packaging>pom</packaging> </parent>