Bootstrap

2024年9月21日---关于Maven

第一节:maven工具的简介

1.1 开发过程中遇到的问题
1、都是同样的代码,为什么在我的机器上可以编译执行,而在他的机器上就不行?
2、为什么在我的机器上可以正常打包,而配置管理员却打不出来?
3、项目组加入了新的人员,我要给他说明编译环境如何设置,但是让我挠头的是,有些细节我也记不清楚了。
4、我的项目依赖一些jar包,我应该把他们放哪里?放源码库里?
5、这是我开发的第二个项目,还是需要上面的那些jar包,再把它们复制到我当前项目的svn库里吧
6、现在是第三次,再复制一次吧。    ----- 这样真的好吗?
7、我写了一个数据库相关的通用类,并且推荐给了其他项目组,现在已经有五个项目组在使用它了,今天我发现了一 
个bug,并修正了它,我会把jar包通过邮件发给其他项目组       -----这不是一个好的分发机制,太多的环节可能导致出现bug
8、项目进入测试阶段,每天都要向测试服务器部署一版。每次都手动部署,太麻烦了。
1.2 什么是maven

Maven是基于项目对象模型(POM),可以通过一小段描述信息来管理项目的构建,报告和文档的软件项目管理工具。Maven是跨平台的项目管理工具。主要服务于基于Java平台的项目构建依赖管理项目信息管理

Maven主要有两个功能:

- 项目构建
- 依赖管理
1.3 什么是构建

1.4 项目构建的方式

1.4.1 Eclipse

<span style="background-color:#f8f8f8"><span style="color:#333333">手工操作较多,项目的构建过程都是独立的,很难一步完成。比如:编译、测试、部署等。
开发时每个人的IDE配置都不同,很容易出现本地代码换个地方编译就出错</span></span>

1.4.2 Ant

<span style="background-color:#f8f8f8"><span style="color:#333333">Ant只是一个项目构建工具,它没有集成依赖管理。
Ant在进行项目构建时,它没有对项目目录结构进行约定,需要手动指定源文件、类文件等目录地址。同时它执行task时,需要显示指定依赖的task,这样会造成大量的代码重复。</span></span>

1.4.3 Maven

<span style="background-color:#f8f8f8"><span style="color:#333333">- Maven不仅是一个项目构建工具,更是一个项目管理工具。它在项目构建工程中,比ant更全面,更灵活。
- Maven在进行项目构建时,它对项目目录结构拥有约定,知道你的源代码在哪里,类文件应该放到哪里去。
- 它拥有生命周期的概念,maven的生命周期是有顺序的,在执行后面的生命周期的任务时,不需要显示的配置前面任务的生命周期。例如执行 mvn install 就可以自动执行编译,测试,打包等构建过程</span></span>

第二节:maven工具的安装

2.1 环境准备
<span style="background-color:#f8f8f8"><span style="color:#333333">PC端:    win11/win10/win7操作系统
Jdk:    jdk-8u172-windows-x64.exe     :   JAVA_HOME  必须配置
maven:  apache-maven-3.5.3-bin.zip</span></span>

maven的历史版本下载地址: Index of /dist/maven/maven-3

2.2 maven解压

将maven的软件包解压到某一个盘符下,如D盘,E盘的某一个你喜欢的路径下;如果你C盘的空间足够大,也可以选择C盘。注意: 你的路径中不要使用中文,也尽量不要带有空格及其他特殊符号

2.3 maven本地仓库配置

2.3.1 创建仓库目录

选择一个你喜欢的位置创建一个文件夹maven_repository,当作maven的本地仓库。起名尽量见名知意

2.3.2 修改settings.xml文件

第一步:打开maven的conf目录下的settings.xml文件

第二步:找到localRepository标记,大概在文件的50行左右,然后配置一下本地仓库路径,指向你创建的仓库目录

例:如图所示

第三步:再配置一下远程仓库的地址。下面给大家的是阿里云的远程仓库地址。

<mirror>  
   <id>alimaven</id>  
   <name>aliyun maven</name>  
   <url>https://maven.aliyun.com/repository/public</url>  
   <mirrorOf>central</mirrorOf>  
</mirror>
<mirror>
   <id>osc</id>
   <url>http://maven.oschina.net/content/groups/public/</url>
   <mirrorOf>central</mirrorOf>
</mirror>

只需要将上述提供的阿里云的地址复制到mirrors标记内部即可,mirrors的结束标记大约在165行左右

第四步:强烈建议,将你的系统盘下Users目录下你的登陆用户名下的.m2目录里的内置的settings.xml文件使用你刚刚配置的maven的settings.xml文件覆盖掉,或者打开此文件,按上述内容配置一下本地仓库,和远程仓库。

如果你不配置这个,那么你以后在使用idea工具时,很可能恢复默认配置哦

2.4 maven环境变量配置

maven的环境变量配置与jdk的环境变量配置非常类似。

2.4.1 添加MAVEN_HOME变量

2.4.2 配置path变量

2.4.3 验证环境变量

出现类似上述的内容,表示配置成功

第三节: IntelliJ IDEA与 maven工具的整合

3.1 idea配置maven

打开idea,按照下图的流程打开,指定maven的根目录,并查看本地仓库的路径是否正确。

3.2 创建maven项目,下载通用jar包

选择 File --> New --> Project --> Maven,勾上create from archetype,选择quickstart,然后Next。

参考下图中的1、2、3、4、5、6、7:

然后 在弹出的新界面中的文本框中进行命名操作,参考下图中的8、9、10:

解析:
- GroupId: 这个文本框对应的是src目录下的包名
- Artifactld: 这个文本框对应的是项目名

点击 上一个图中的Next后,来到如下窗口,确定序号11是不是你安装的maven,如果不是,选择一下你自己的maven路径。然后12,13完成项目的创建。

注意: 当你刚刚创建完项目后,会出现如下界面,downloading表示正在从阿里云的远程仓库下载jar包到你的本地仓库中。第一次下载的时间可能会久一点。如果想要将jar包导入项目中,请点击右下角的Enable Auto-import

查看你的本地仓库目录,应该有内容了。例:如下图示

第四节:联网下载jar包导入本地maven库

4.1 常用maven仓库地址
https://mvnrepository.com/
https://maven.aliyun.com/mvn/search
4.2 下载hadoop的jar包到本地仓库

打开 https://mvnrepository.com/网址,搜索hadoop

先找到 hadoop-common,点进去,找到相应版本号,进去查看maven的dependency信息。

将dependency的内容,全选,复制到项目的pom.xml文件中的dependencies标签内部,如下图

然后,其他的jar包,如hadoop-client、hadoop-hdfs、hadoop-mapreduce-client-core这些jar的pom信息也依次复制到项目下的pom.xml文件中。

pom.xml内容如下:

<dependencies>
    <!-- https://mvnrepository.com/artifact/org.apache.hadoop/hadoop-common-->
    <dependency>
        <groupId>org.apache.hadoop</groupId>
        <artifactId>hadoop-common</artifactId>
        <version>2.7.6</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.apache.hadoop/hadoop-hdfs-->
    <dependency>
        <groupId>org.apache.hadoop</groupId>
        <artifactId>hadoop-hdfs</artifactId>
        <version>2.7.6</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.apache.hadoop/hadoop-mapreduce-client-core -->
    <dependency>
        <groupId>org.apache.hadoop</groupId>
        <artifactId>hadoop-mapreduce-client-core</artifactId>
        <version>2.7.6</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.apache.hadoop/hadoop-client-->
    <dependency>
        <groupId>org.apache.hadoop</groupId>
        <artifactId>hadoop-client</artifactId>
        <version>2.7.6</version>
    </dependency>
</dependencies>

这样 配置完,就会自动从远程仓库中下载这四个jar包,以及依赖的所有jar包到你的本地库了。

例:如下图示

第五节:在idea中创建maven项目

  1. 打开IntelliJ IDEA,点击"File" -> "New" -> "Project"。

  2. 在弹出的窗口中,选择左侧的"Maven"选项。

  3. 在右侧的面板中,勾选"Create from archetype"选项,然后在下拉列表中选择一个适合你的项目的archetype。例如,如果你要创建一个Java项目,可以选择"maven-archetype-quickstart"。

  4. 点击"Next"按钮,进入下一步。

  5. 在下一个窗口中,填写项目的基本信息,如GroupId、ArtifactId、Version等。这些信息将用于生成项目的目录结构和pom.xml文件。

  6. 点击"Next"按钮,进入下一步。

  7. 在下一个窗口中,选择项目的存储位置和名称,然后点击"Finish"按钮。

  8. IntelliJ IDEA将自动创建一个新的Maven项目,并下载所需的依赖库。完成后,你可以在项目中看到生成的目录结构和pom.xml文件。

  9. 现在你可以开始编写代码并使用Maven构建和管理项目了。

;