Maven从浅入深(理解篇)

前言

在软件开发领域,包管理器是不可或缺的工具,它们帮助开发者管理和维护项目中的依赖库。通过对比.NET的NuGet包、Python的pip包以及Java的Maven,我们可以从原理上更深刻地理解这些工具的作用和差异。

1. NuGet(.NET)


原理与功能

  • 定义:NuGet是微软为.NET平台(包括.NET Framework和.NET Core)提供的程序集共享包管理工具。它允许开发者创建、共享和使用.NET包。
  • 工作方式 :NuGet包通常以.nupkg文件形式存在,这是一个ZIP包,包含编译后的代码(.dll文件)、其他相关文件以及包的描述信息(如版本号)。开发者可以通过NuGet客户端(如Visual Studio中的NuGet包管理器)或命令行工具来安装包、更新包或卸载包。
  • 依赖管理:NuGet自动处理包与包之间的依赖关系,确保项目依赖的所有包都被正确安装和版本控制。

2. pip(Python)


原理与功能

  • 定义:pip是Python的包安装器,用于安装和管理Python包。它允许用户从Python包索引(PyPI)安装和管理包。
  • 工作方式:pip通过命令行界面与PyPI交互,下载并安装用户指定的包及其依赖项。pip还支持包的版本管理,允许用户指定安装特定版本的包。
  • 依赖管理:pip会自动解决并安装包的依赖项,确保项目的依赖环境是完整和一致的。

3. Maven(Java)


原理与功能

  • 定义:Maven是一个项目管理工具,它主要用于Java项目的构建、依赖管理和项目信息管理。Maven通过其项目对象模型(POM)和约定的目录结构来管理项目。
  • 工作方式 :Maven使用pom.xml文件作为项目的配置文件,其中定义了项目的依赖关系、构建过程、插件等。Maven根据pom.xml中的配置自动下载和管理项目所需的依赖库,并执行构建过程(如编译、测试、打包等)。
  • 依赖管理:Maven通过中央仓库(如Maven Central)和本地仓库来管理项目的依赖库。它会自动解析项目依赖,并下载和安装所有必要的依赖库及其传递性依赖。

4. 对比


NuGet pip Maven
平台 .NET Python Java
配置文件 无特定文件(通过NuGet包管理器或命令行操作) 无特定文件(通过pip命令操作) pom.xml
包格式 .nupkg(ZIP包) 多种格式,但通常以.whl.tar.gz为主 JAR包、WAR包等
仓库 NuGet官方仓库、私有仓库 PyPI、私有仓库 Maven Central、私有仓库
功能 包管理、依赖管理 包安装、依赖管理 项目构建、依赖管理、项目信息管理
自动化程度 高(自动处理依赖) 高(自动处理依赖) 非常高(不仅管理依赖,还管理项目构建)

Part1:Maven概念

蓝色区域代表maven的核心。蓝色虚线下面的是maven本身的东西,而上面的就是项目中需要处理的模块。

Maven是基于java开发的

1.1. 概念


Maven的本质是一个项目管理工具将项目开发和管理过程抽象成一个项目对象模型(POM)

POM(Project OBject Model):对项目对象模型

Maven使用pom.xml配置文件获取项目信息

【Maven如何实现帮我们管理资源?】

依赖管理的包都是基于中央仓库拿到的。

使用本地,私服,中央仓库。

使用场景:

基础模块依赖;

Jar包版本冲突(mybatis如果进行版本升级,他依赖的的版本也需要升级,那么需要同步进行)

1.2. maven的作用


项目构建:提供标准的、跨平台的自动化项目构建方式。

依赖管理:方便快捷的管理项目依赖的资源(jar包),避免资源间的版本冲突问题。

开发结构的统一:提供标准的、统一的项目结构

Park2:Maven下载安装

2.1. 下载


官网:Maven -- Welcome to Apache Maven

直接下载,绿色版软件解压即可。

2.2. 目录结构


  • [核心运行文件
    类加载器
    配置
    文件依赖包](#核心运行文件 类加载器 配置 文件依赖包)

2.3. 配置环境变量


(1) java环境变量(一般都有,不知道的自行搜索吧)

没有的会报错哟:

Dart 复制代码
The JAVA_HOME environment variable is not defined correctly,
// JAVA_HOME环境变量未正确定义,
this environment variable is needed to run this program.
// 运行此程序需要此环境变量。

(2)配置maven

【第 1 步】增加MAVEN_HOME路径

【第 2 步】追加PATH

【第 3 步】验证

如何确认maven安装成功呢,直接输入在cmd窗口输入maven命令即可。

XML 复制代码
C:\Users\username>mvn
[INFO] Scanning for projects...
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time:  0.078 s
[INFO] Finished at: 2024-09-15T07:13:43+08:00
[INFO] ------------------------------------------------------------------------
[ERROR] No goals have been specified for this build. You must specify a valid lifecycle phase or a goal in the format <plugin-prefix>:<goal> or <plugin-group-id>:<plugin-artifact-id>[:<plugin-version>]:<goal>. Available lifecycle phases are: pre-clean, clean, post-clean, validate, initialize, generate-sources, process-sources, generate-resources, process-resources, compile, process-classes, generate-test-sources, process-test-sources, generate-test-resources, process-test-resources, test-compile, process-test-classes, test, prepare-package, package, pre-integration-test, integration-test, post-integration-test, verify, install, deploy, pre-site, site, post-site, site-deploy. -> [Help 1]
[ERROR]
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR]
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/NoGoalSpecifiedException

Park3:Maven基础配置

3.1 仓库


3.1.1. 概念

仓库:用于存储资源,包含各种jar包.

3.1.2. 分类

中央仓库

在云服务器上,maven团队自己管理.这里存放这所有用到的公共jar包.

本地仓库(子集)

从中央仓库下载的jar会存储到开发者自己本机

私服

全世界的开发者都从中央仓库拉取jar,首先maven官网可能是承受不了的,他必要进行限流吧。

对于开发者来说,也会消耗带宽去下载,也会浪费资源。

公司为了让开发者快速下载依赖,提高效率,那么私服就出现了。

那么开发者在拉jar包是,不再去中央仓库,而是先去私服去找,如果没有再去中央仓库去寻找.

扩展理解:

就好比DNS镜像服务服务器一样,所有的域名都走13个根节点服务器,那还不得把根服务器类累死,所以就有了这种镜像的东西。

私服的其他作用:

一定范围内共享资源,仅对内部开放,不对外共享.

3.2 Maven-坐标


maven中央仓库存储这大量的资源,资源在查找的时候如何查询?

Maven就是通过坐标去管理的。

3.2.1. 坐标概念


Maven中的坐标用于描述仓库中资源的位置。

https://repo1.maven.org/maven2/

3.2.2. 坐标组成


组织名、项目名、版本号、打包方式

XML 复制代码
  <groupId>com.alibaba.fastjson2</groupId>
   <artifactId>fastjson2</artifactId>
   <version>2.0.52</version>
  • 组织:groupid 定义当前Maven项目隶属组织名称(通常是域名反写,例如:org.mybatis)
  • 项目名:artifactid 定义当前Maven项目名称(通常是模块名称,例如CRM、SMS)
  • 版本号:version 定义当前相关目的版本号
  • 打包方式:packaging:定义该项目的打包方式。

如何查看你要导入项目的坐标呢?

通过下面的地址进行搜索、进入后选择版本号就可以看到下面第二幅图了里面的xml坐标了。

https://mvnrepository.com/artifact/com.alibaba.fastjson2/fastjson2/2.0.52

3.2.3. Maven坐标作用


使用唯一标识,唯一性定位资源位置,通过该标识可以将资源的识别与下载工作交由机器完成

3.3 仓库配置


3.3.1. 配置仓库

XML 复制代码
  <!--修改计算机缓存仓库地址-->
<localRepository>F:\99-wxd\99-mavenData\repository</localRepository>  
  <!--修改镜像地址-->
  <mirrors>	
     <mirror>
     <!-- id 镜像唯一标识符,用来区分不同的镜像对象-->
      <id>aliyunmaven</id>
     <!-- 对哪种仓库进行镜像,简单的说就是替代哪个仓库-->
	  <mirrorOf>central</mirrorOf>
     <!-- 镜像名称,可以自定义-->
	  <name>阿里云公共仓库</name>
     <!-- 镜像Url-->
	  <url>https://maven.aliyun.com/nexus/content/groups/public/</url>
	</mirror>
  </mirrors>

添加好了之后,注意把你的idea也要修改下,maven使用你安装的maven,配置使用上面配置好的配置,然后刷新下maven依赖。

如果看到配置地址里 "F:\99-wxd\99-mavenData\repository"里面缓存了文件那么就是ok了。

3.3.2. 全局setting、用户setting


这俩配置要保持一致。

  • 全局settting:(maven包里面的setting)定义了当前计算器中Maven的公共配置
  • 用户settting:(仓库文件的setting)定义了当前用户的配置

Park4: Maven项目里使用

4.1 相关目里配置


4.2 Maven构建命令


Dart 复制代码
mvn compile            # 编译

mvn clean              # 清理

mvn test               # 测试

mvn package            # 打包

mvn install            # 安装到本地仓库

在草稿箱好久了,先发出来,后面再追加完善......

相关推荐
xmh-sxh-13146 分钟前
jdk各个版本介绍
java
天天扭码25 分钟前
五天SpringCloud计划——DAY2之单体架构和微服务架构的选择和转换原则
java·spring cloud·微服务·架构
程序猿进阶25 分钟前
堆外内存泄露排查经历
java·jvm·后端·面试·性能优化·oom·内存泄露
FIN技术铺30 分钟前
Spring Boot框架Starter组件整理
java·spring boot·后端
小曲程序37 分钟前
vue3 封装request请求
java·前端·typescript·vue
陈王卜1 小时前
django+boostrap实现发布博客权限控制
java·前端·django
小码的头发丝、1 小时前
Spring Boot 注解
java·spring boot
java亮小白19971 小时前
Spring循环依赖如何解决的?
java·后端·spring
飞滕人生TYF1 小时前
java Queue 详解
java·队列
武子康1 小时前
大数据-230 离线数仓 - ODS层的构建 Hive处理 UDF 与 SerDe 处理 与 当前总结
java·大数据·数据仓库·hive·hadoop·sql·hdfs