1. 学习Maven的重要性与必要性
为什么需要在项目中使用maven工具,一般都有以下几个方面的考量。
1.1 Maven作为依赖管理工具
随着项目使用的框架越来越多,或者框架的封装程度越来越高,项目中使用的jar包会越来越多。在一个项目中,一个模块都可能达到上百的jar包。
比如我们只使用SpringBoot框架中的一个web框架环境功能。此时项目中就会导入大量的jar包。可以看到,如此多的jar包如果全靠人工管理,那么这将是一个非常耗时的任务。
如果我们使用Maven来引入这些依赖,我们只需要在pom.xml中添加一个依赖即可。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
jar的来源
- 前往提供jar包所属的技术网站下载
- 第三方网站下载。主要问题是不规范,在使用过程中可能会出现各种问题。
- 在使用Maven之后,依赖对应的jar包能够自动下载,使用十分方便、方便和规范。
jar包之间的依赖关系
框架中使用的jar包,不仅数量众多,而且彼此之间存在错中复杂的依赖关系。这些依赖关系的复杂性已经上升到人力难以维护的程度。另外,jar包之间还可能产生冲突,也会增加jar包的使用难度。
下图为上面例子中jar包的依赖关系:
由这个依赖图可以看到,各个jar包之间的依赖关系是错中复杂的,如果纯靠人工来维护这些依赖关系是十分繁琐的。这时使用Maven管理这些关系时,我们就可以较为清晰的看到依赖关系,并且调整起来也会更方便。
1.2 Maven作为项目构建工具
即使不使用Maven,我们创建项目也需要经历构建过程,只是平时我们通常会使用集成开发环境IDEA时,IDEA会帮我们完成构建过程。
那么脱离IDEA时,常见的项目开发构建过程。
因此,我们管理规模庞大的jar包,需要专门的工具;我们脱离IDE集成环境进行项目构建操作,也需要专门的工具;所以就需要使用Maven了。
2. 什么是Maven?
Maven是由Apache软件基金组织维护的一款专门为Java项目提供构建和依赖管理的工具。
2.1 构建
Java项目的开发过程中,构建就是指将原材料生产称产品的过程。
- 原材料
- Java源代码
- HTMl页面文件
- 图片等静态资源
- 项目配置文件
- 等等
- 产品
- 一个可以在服务器上运行的项目
构建过程包含的主要环节:
- 清理:删除上一次构建的结果,为下一次构建做好准备。
- 编译:Java源代码编译成字节码文件
- 测试:运行提前准备好的测试程序
- 报告:正对测试结果,生成一个全面的反馈信息。
- 打包:Java工程一般打成jar包;Web工程一般打成war包。
- 安装:把一个Maven工程经过打包操作生成的jar包或者war包存入Maven仓库中。
- 部署:部署jar包一般是将一个jar包部署到Nexus私服服务器上;部署war包一般是借助相关Maven插件(例如cargo),将war包部署到Tomcat服务器上。
2.2 依赖
如果A工程中使用到了B工程中的类、接口、配置文件等等资源,那么就可以称为A工程依赖B工程。
- thymeleaf-3.0.12.RELEASE 依赖 ognl-3.1.26
ognl-3.1.26 依赖 javassist-3.20.0-GA - thymeleaf-3.0.12.RELEASE 依赖 attoparser-2.0.5.RELEASE
- thymeleaf-3.0.12.RELEASE 依赖 unbescape-1.1.6.RELEASE
- thymeleaf-3.0.12.RELEASE 依赖 slf4j-api-1.7.26
依赖管理中要解决的具体问题:
- jar 包的下载:使用 Maven 之后,jar 包会从规范的远程仓库下载到本地
- jar 包之间的依赖:通过依赖的传递性自动完成
- jar 包之间的冲突:通过对依赖的配置进行调整,让某些jar包不会被导入