百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

Maven解析让你从新手到高手

yuyutoo 2025-01-19 01:30 2 浏览 0 评论

背景

本文从实战角度出发,笔者多年经验总结,能让你快速理解Maven,知其然且知其所以然,全是干货,让我们开始吧。

文章概览

  1. Maven能做什么
  2. Maven自身配置
  3. Maven插件管理
  4. Pom文件介绍
  5. Maven其他

1.Maven能做什么

Maven是一个软件项目管理工具,主要用于构建和管理项目,功能比较丰富。在这里笔者着重想告诉你,Maven主要干两件事:

  1. Jar包依赖管理 在项目中使用第三方jar是再正常不过的一件事,大家也习以为常。没有maven之前项目使用jar需要我们手动下载,遇到jar依赖问题不得不继续下载直到把所有的jar包下载到项目中,这个过程是痛苦的也浪费程序员宝贵时间。但Jason Van Zyl这位牛逼的程序员搞定了这件事,他开发的Maven工具可以帮你解决下载jar包,若遇到jar包依赖还能自动下载依赖的jar包,整个过程只需要程序员设定一下配置文件即可完成。
  2. 提供标准目录结构 Maven能统一项目目录,这是怎么回事呢?在没有maven工具之前,每个项目的目录结构不同,比如A项目有3个文件夹,B项目有4个文件夹,在小范围内研发没有问题,一旦范围扩大就没有章法显得目录管理混乱。于是Maven就提供统一目录结构,告诉人们只要你用Maven就会是像下面这样结构。


2.Maven自身配置

  1. 下载安装Maven 需要提前安装好JDK,然后官网下载需要的版本,注意Maven版本与JDK版本匹配,然后配置Maven环境变量M2_HOME=安装路径,添加path变量%M2_HOME%\bin,CMD窗口执行mvn -v验证。
  2. setting.xml文件 该文件有内有很多元素,每个元素代表不同含义,本文介绍比较常用的几个:<localRepository></localRepository>:指定下载来的jar包保存目录,默认位置${user.home}/.m2/repository<servers></servers>:如果有私服,这里可以配置服务器认证信息,以便Maven能够访问和上传到指定的仓库<mirror></mirror>:jar包下载地址,一般国内配置阿里云镜像地址http://maven.aliyun.com/nexus/coptent/groups/public<profiles></profiles>:定义一组配置集合,适应不同环境,比如开发、测试、生产,POM文件<properties>元素引用该组配置,并激活其中一个。

3.Maven插件管理

Maven是通过各种各样的插件管理项目的,Maven自身仅仅是一个框架,常用的插件比如有cleancompilerinstalljarwarinstall等,这些插件也是由Apache提供,插件列表请查看官网。

4.POM文件介绍

POM.xml文件是project object model缩写,翻译过来叫项目对象模型,说人话就是用它来定义每个项目,该文件也是xml格式,每个元素代表不同含义,本文介绍常用几个:

  1. <parent></parent>:这个元素定义当前模块的父项目的坐标(groupid、artifactid、version)。
  2. <properties></properties>:用于定义项目使用的属性,比如JDK版本、项目版本、或者jar版本,该元素可以继承。
  3. <dependencyManagement></dependencyManagement>:父项目声明依赖,能让所有子项目中引用依赖且不用显示列出版本号。
  4. <dependencies></dependencies>:显示具体依赖,在父子项目中,该元素可以继承。
  5. <profiles><profile></profile></profiles>:定义不同的构建环境,比如开发、测试、生产环境。
  6. <build><plugins><plugin></plugin></plugins></build>:项目中需要使用的使用的插件,该元素可以继承。
  7. <build><resources>><resource></resource></resources></build>:构建项目中处理配置文件,比如将某个配置文件打包到指定项目路径。
  8. <distributionManagement><repository></<repository>></distributionManagement>:该元素将构建的结果比如jar、war发布到远程仓库,该元素可以配置远程仓库主仓库和快照仓库(id、name、url),与setting.xml中的servers元素对应。
  9. <repositories><repository></repository></repositories>:项目构建过程中需要访问的所有外部Maven仓库配置。
  10. <pluginRepositories></pluginRepositories>:项目构建过程中可以从这个仓库下载插件,指定专门的插件仓库地址。

5.Maven其他

  1. Maven在大项目中管理多模块,模块与模块间存在三种关系:
    1. 依赖:假设模块service-module依赖common-module,在pom文件中直接使用<dependency>引用。
    2. 继承:若模块与模块之间存在继承关系,则子模块在pom文件中直接使用<parent>引用父坐标。
    3. 聚合:聚合将多个子模块组织在一起,由父模块协调子模块构建,子模块有自己的业务逻辑,有单独的pom.xml文件,可以独立部署。先有一个聚合项目,父模块名称aggregator-project,子模块名称module-a,父子模块在同级目录下,当父模块进行构建时,会先进入上一级目录,在上一目录中搜素子目录。父POM文件<modules>定义子模块,例如:<module>../module-a</module>,子模块POM文件<parent>引用父模块,例如:<parent><relativePath>../aggregator-project/pom.xml</relativePath></parent>
聚合关系:父POM
<!-- aggregator-project/pom.xml -->
 <project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
     <modelVersion>4.0.0</modelVersion>

     <groupId>com.example</groupId>
     <artifactId>aggregator-project</artifactId>
     <version>1.0.0</version>
     <packaging>pom</packaging>

     <modules>
         <module>../module-a</module>
         <module>../module-b</module>
     </modules>
 </project>
聚合关系:子POM
<!-- module-a/pom.xml -->

 <project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
     <modelVersion>4.0.0</modelVersion>

     <parent>
         <groupId>com.example</groupId>
         <artifactId>aggregator-project</artifactId>
         <version>1.0.0</version>
         <relativePath>../aggregator-project/pom.xml</relativePath>
     </parent>

     <artifactId>module-a</artifactId>
 </project>
  1. Maven常用命令:
    1. mvn clean:重新构建之前删除target目录及内容,清理旧的编译结果
    2. mvn compile:将java源码编译成字节码
    3. mvn test:执行单元测试
    4. mvn package:打包项目,生成最终文件,如:jar、war
    5. mvn install:将JAR文件安装到本地Maven仓库(通常位于 ~/.m2/repository 目录下),方便其他项目引用
    6. mvn deploy:将项目部署到远程仓库,通过pom.xml中的<distributionManagement>,找到setting.xml中的<servers>元素
    7. mvn clean install:组合命令,先清理项目,然后编译、测试并安装到本地仓库
    8. mvn clean package:组合命令,先清理项目,然后编译、测试并打包项目
    9. mvn test -DskipTests:组合命令,跳过测试直接编译打包
    10. mvn dependency:tree:组合命令,检查项目中使用的依赖关系及其版本
    11. mvn archetype:generate:组合命令,根据当前项目,生成新的Maven模版,在创建新的项目时候使用自己自定义的模版
  2. Maven工具执行流:

总结

Maven工具为目前项目构建使用率较高的工具,了解和掌握该工具能大大提高研发效率,请多多实践本文中的相关介绍。

相关推荐

史上最全的浏览器兼容性问题和解决方案

微信ID:WEB_wysj(点击关注)◎◎◎◎◎◎◎◎◎一┳═┻︻▄(页底留言开放,欢迎来吐槽)●●●...

平面设计基础知识_平面设计基础知识实验收获与总结
平面设计基础知识_平面设计基础知识实验收获与总结

CSS构造颜色,背景与图像1.使用span更好的控制文本中局部区域的文本:文本;2.使用display属性提供区块转变:display:inline(是内联的...

2025-02-21 16:01 yuyutoo

写作排版简单三步就行-工具篇_作文排版模板

和我们工作中日常word排版内部交流不同,这篇教程介绍的写作排版主要是用于“微信公众号、头条号”网络展示。写作展现的是我的思考,排版是让写作在网格上更好地展现。在写作上花费时间是有累积复利优势的,在排...

写一个2048的游戏_2048小游戏功能实现

1.创建HTML文件1.打开一个文本编辑器,例如Notepad++、SublimeText、VisualStudioCode等。2.将以下HTML代码复制并粘贴到文本编辑器中:html...

今天你穿“短袖”了吗?青岛最高23℃!接下来几天气温更刺激……

  最近的天气暖和得让很多小伙伴们喊“热”!!!  昨天的气温到底升得有多高呢?你家有没有榜上有名?...

CSS不规则卡片,纯CSS制作优惠券样式,CSS实现锯齿样式

之前也有写过CSS优惠券样式《CSS3径向渐变实现优惠券波浪造型》,这次再来温习一遍,并且将更为详细的讲解,从布局到具体样式说明,最后定义CSS变量,自定义主题颜色。布局...

柠檬科技肖勃飞:大数据风控助力信用社会建设

...

你的自我界限够强大吗?_你的自我界限够强大吗英文

我的结果:A、该设立新的界限...

行内元素与块级元素,以及区别_行内元素和块级元素有什么区别?

行内元素与块级元素首先,CSS规范规定,每个元素都有display属性,确定该元素的类型,每个元素都有默认的display值,分别为块级(block)、行内(inline)。块级元素:(以下列举比较常...

让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华
让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华

去年的两会期间,习近平总书记在参加人大会议四川代表团审议时,对治蜀兴川提出了明确要求,指明了前行方向,并带来了“祝四川人民的生活越来越安逸”的美好祝福。又是一年...

2025-02-21 16:00 yuyutoo

今年国家综合性消防救援队伍计划招录消防员15000名

记者24日从应急管理部获悉,国家综合性消防救援队伍2023年消防员招录工作已正式启动。今年共计划招录消防员15000名,其中高校应届毕业生5000名、退役士兵5000名、社会青年5000名。本次招录的...

一起盘点最新 Chrome v133 的5大主流特性 ?

1.CSS的高级attr()方法CSSattr()函数是CSSLevel5中用于检索DOM元素的属性值并将其用于CSS属性值,类似于var()函数替换自定义属性值的方式。...

竞走团体世锦赛5月太仓举行 世界冠军杨家玉担任形象大使

style="text-align:center;"data-mce-style="text-align:...

学物理能做什么?_学物理能做什么 卢昌海

作者:曹则贤中国科学院物理研究所原标题:《物理学:ASourceofPowerforMan》在2006年中央电视台《对话》栏目的某期节目中,主持人问过我一个的问题:“学物理的人,如果日后不...

你不知道的关于这只眯眼兔的6个小秘密
你不知道的关于这只眯眼兔的6个小秘密

在你们忙着给熊本君做表情包的时候,要知道,最先在网络上引起轰动的可是这只脸上只有两条缝的兔子——兔斯基。今年,它更是迎来了自己的10岁生日。①关于德艺双馨“老艺...

2025-02-21 16:00 yuyutoo

取消回复欢迎 发表评论: