Maven(一):什么是Maven?

  • 前言
  • 一、为什么要学习Maven?
    • 1、Maven 作为依赖管理工具
      • 1.1 jar 包的规模
      • 1.2 jar 包的来源
      • 1.3 jar 包之间的依赖关系
    • 2、Maven 作为构建管理工具
      • 2.1 你没有注意过的构建
      • 2.2 脱离 IDE 环境仍需构建
    • 3、结论
  • 二、什么是 Maven?
    • 1、构建
    • 2、依赖
    • 3、Maven 的工作机制

前言

本博主将用CSDN记录软件开发求学之路上亲身所得与所学的心得与知识,有兴趣的小伙伴可以关注博主!也许一个人独行,可以走的很快,但是一群人结伴而行,才能走的更远!



一、为什么要学习Maven?

1、Maven 作为依赖管理工具

1.1 jar 包的规模

随着我们使用越来越多的框架,或者框架封装程度越来越高,项目中使用的jar包也越来越多。项目中,一个模块里面用到上百个jar包是非常正常的。

比如下面的例子,我们只用到 SpringBootSpringCloud 框架中的三个功能:

Nacos 服务注册发现
Web 框架环境
③ 图模板技术 Thymeleaf
最终却导入了 106 个 jar

而如果使用 Maven 来引入这些 jar 包只需要配置三个『依赖』:

<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-thymeleaf</artifactId></dependency>

1.2 jar 包的来源

⭕ 这个jar包所属技术的官网。官网通常是英文界面,网站的结构又不尽相同,甚至找到下载链接还发现需要通过特殊的工具下载。

⭕ 第三方网站提供下载。问题是不规范,在使用过程中会出现各种问题。

  1. jar包的名称
  2. jar包的版本
  3. jar包内的具体细节

⭕ 而使用 Maven 后,依赖对应的 jar 包能够自动下载,方便、快捷又规范。

1.3 jar 包之间的依赖关系

框架中使用的 jar 包,不仅数量庞大,而且彼此之间存在错综复杂的依赖关系。依赖关系的复杂程度,已经上升到了完全不能靠人力手动解决的程度。另外,jar包之间有可能产生冲突。进一步增加了我们在 jar 包使用过程中的难度。

下面是前面例子中 jar 包之间的依赖关系:

而实际上 jar 包之间的依赖关系是普遍存在的,如果要由程序员手动梳理无疑会增加极高的学习成本,而这些工作又对实现业务功能毫无帮助。

而使用 Maven 则几乎不需要管理这些关系,极个别的地方调整一下即可,极大的减轻了我们的工作量。

2、Maven 作为构建管理工具

2.1 你没有注意过的构建

你可以不使用 Maven,但是构建必须要做。当我们使用 IDEA 进行开发时,构建是 IDEA 替我们做的。

2.2 脱离 IDE 环境仍需构建

3、结论

⭕ 管理规模庞大的 jar 包,需要专门工具。
⭕ 脱离 IDE 环境执行构建操作,需要专门工具。

二、什么是 Maven?

Maven 是 Apache 软件基金会组织维护的一款专门为 Java 项目提供构建和依赖管理支持的工具。

1、构建

Java 项目开发过程中,构建指的是使用原材料生产产品的过程。

⭕ 原材料

  1. Java 源代码

  2. 基于 HTMLThymeleaf 文件

  3. 图片

  4. 配置文件

⭕ 产品

  1. 一个可以在服务器上运行的项目

⭕ 构建过程包含的主要的环节:
● 清理:删除上一次构建的结果,为下一次构建做好准备
● 编译:Java 源程序编译成 *.class 字节码文件
● 测试:针对项目中的关键点进行测试,确保项目在迭代开发过程中关键点的正确性。
● 报告:在每一次测试后以标准的格式记录和展示测试结果。
● 打包:将一个包含诸多文件的工程封装为一个压缩文件用于安装或部署。

  1. Java工程:jar
  2. Web工程:war

● 安装:把一个 Maven工程经过打包操作生成的 jar 包或 war 包存入 Maven 仓库
● 部署

  1. 部署 jar 包:把一个 jar 包部署到 Nexus私服服务器上
  2. 部署 war 包:借助相关 Maven 插件(例如 cargo),将 war 包部署到 Tomcat 服务器上

2、依赖

⭕ 如果 A 工程里面用到了 B 工程的类、接口、配置文件等等这样的资源,那么我们就可以说 A 依赖 B。例如:

  1. junit-4.12 依赖 hamcrest-core-1.3
  2. thymeleaf-3.0.12.RELEASE 依赖 ognl-3.1.26
  3. ognl-3.1.26 依赖 javassist-3.20.0-GA
  4. thymeleaf-3.0.12.RELEASE 依赖 attoparser-2.0.5.RELEASE
  5. thymeleaf-3.0.12.RELEASE 依赖 unbescape-1.1.6.RELEASE
  6. thymeleaf-3.0.12.RELEASE 依赖 slf4j-api-1.7.26

⭕ 依赖管理中要解决的具体问题:

jar 包的下载:使用 Maven 之后,jar 包会从规范的远程仓库下载到本地
jar 包之间的依赖:通过依赖的传递性自动完成
jar包之间的冲突:通过对依赖的配置进行调整,让某些jar包不会被导入

3、Maven 的工作机制