【Maven教程】(一)入门介绍篇:Maven基础概念与其他构建工具:理解构建过程与Maven的多重作用,以及与敏捷开发的关系 ~

Maven入门介绍篇

  • 1️⃣ 基础概念
      • 1.1 构建
      • 1.2 maven对构建的支持
      • 1.3 Maven的其他作用
  • 2️⃣ 其他构建工具
      • 2.1 IDE
      • 2.2 Make
      • 2.3 Ant
      • 2.4 Jenkins
  • 3️⃣ Maven与敏捷开发
  • 🌾 总结

在这里插入图片描述

1️⃣ 基础概念

"Maven"可以翻译为 “知识的积累者” 或 “专家”。这个词源于波斯语,意为广受尊重和富有智慧的人。在软件开发领域中,Maven作为Apache 组织中的一个颇为成功的开源项目,它是一个非常流行的构建工具,它在项目管理、依赖管理和构建自动化方面提供了强大的功能和支持。因此,Maven 被视为软件开发过程中的权威专家,能够帮助开发团队更高效地构建和管理项目。

无论是小型的开源类库项目还是大型的企业级应用,无论是传统的瀑布式开发还是流行的敏捷模式,Maven都能展现其出色的能力。

1.1 构建

其实作为程序员,我们每天都在进行构建(build)工作。上班后的第一件事就是从源代码库中拉取最新的代码,并进行单元测试。如果测试失败,我们会与同事合作进行调试修复。然后我们继续自己的工作,编写单元测试和产品代码。

忙碌到中午,代码编写基本完成,测试也通过了,我们开心地享用午餐并稍作休息。下午开始有些困倦的时候,我们参加例会,会议结束后喝杯咖啡继续工作。刚才在会议中经理要求查看测试报告,于是我们将相关工具集成到IDE中,生成漂亮的测试覆盖率报告,然后发邮件给经理,松了口气。但QA小组又提交了几个bug,没办法,我们先在本地重现,然后熟练地用IDE生成一个WAR包,部署到Web容器中启动进行测试。一步步复现问题,最后在下班前修复了bug,提交代码并通知QA小组,愉快地结束了一天的工作。

回想一下,除了编写源代码,我们每天也花很多时间来进行编译、运行单元测试、生成文档、打包和部署等繁琐的工作,也就是构建。如果仍然依赖手工完成这些步骤,成本将会非常高。因此,有人通过使用软件方法完全自动化这一系列工作,使得软件构建像流水线一样自动进行,只需简单的一条命令,所有繁杂的步骤都能够自动完成,很快就能得到最终结果。

1.2 maven对构建的支持

上面就介绍了Maven 的用途之一是服务于构建,它是一个强大的构建工具,能够帮我们完成自动化构建过程,从清理、编译、测试到生成报告,再到打包和部署。我们不需要一遍遍地输入命令, 我们要做的是使用Maven 配置好项目,然后输入简单的命令(如 mvn clean install),Maven 就会帮我们处理那些烦琐的任务。

Maven是一个跨平台的构建工具,这意味着不管是在WindowsLinux还是Mac上,我们都可以使用相同的命令进行构建。

我们一直在努力寻找避免重复的方法,包括设计、编码、文档以及构建的重复。而Maven最大程度地消除了构建过程中的重复性工作。它抽象了构建生命周期,并提供了许多已实现的插件来完成大部分构建任务。我们不再需要定义过程,甚至不需要实现其中的一些任务。举个简单的例子,对于测试来说,我们只需要按照Maven的约定编写好测试用例,当进行构建时,这些测试会自动运行,无需告诉Maven如何执行测试。

想象一下,Maven抽象了一个完整的构建生命周期模型,吸取了其他构建脚本和工具的优点,并总结了大量项目的实际需求。如果我们遵循这个模型,在很多情况下可以避免许多不必要的错误。此外,我们可以直接使用许多成熟的Maven插件来完成任务。

总的来说,Maven作为一个构建工具,具有自动化构建的能力,同时还能够提供抽象的构建过程和已实现的构建任务。它的跨平台特性以及提供一致操作接口的特点,使其成为出色且广受欢迎的构建工具。

1.3 Maven的其他作用

图1 Maven的logo

Maven不只是一个构建工具,还是一个依赖管理及项目信息管理工具,它通过提供中央仓库来支撑开发者自动下载组件。

在当今开源的编程时代,几乎所有的Java应用都会使用一些第三方的开源类库,这些类库可以通过依赖的方式引入到项目中。然而,随着依赖的增加,就可能会出现版本不一致、版本冲突、依赖臃肿等问题。手动解决这些问题非常繁琐,但幸运的是Maven为我们提供了一个优秀的解决方案。通过依赖坐标系统,Maven能够精确定位每一个组件(比如jar文件),使类库世界变得有秩序。借助Maven,我们可以有序地管理依赖,轻松解决复杂的依赖问题。

此外,Maven还帮助我们有效管理项目中分散在各个角落的项目信息,包括项目描述、开发者列表、版本控制系统地址、许可证、缺陷管理系统地址等等。这些微小的变化可能看起来不起眼,但却在不知不觉中节省了大量查找信息的时间。除了直接的项目信息,Maven还生成网站和提供一些已有插件,使我们轻松获得有价值的项目信息,比如项目文档、测试报告、静态分析报告、源码版本日志报告等。

另外,Maven还为全球的Java开发者提供了一个免费的中央仓库,在这个仓库中几乎可以找到任何流行的开源类库。通过一些衍生工具(如Nexus),我们甚至可以快速搜索中央仓库。只要提供坐标,Maven就能自动下载所需的文件,省去了手工操作的麻烦。

最后,使用Maven还能享受一个额外的好处,即Maven为项目提供了规范的目录结构、测试用例命名方式等。只要按照这些成熟的规则进行开发,切换项目时无需额外学习,符合"约定优于配置"的原则。

2️⃣ 其他构建工具

Maven 不是Java 领域唯一的构建管理的解决方案。本节将通过一些简单的例子解释Maven的必要性,并介绍其他构建解决方案,如IDEMakeAnt, 并将它们与 Maven 进行比较。

2.1 IDE

我们不能否认优秀的集成开发环境(IDE)可以极大地提高开发效率。主流的IDEEclipseNetBeans等,提供了强大的文本编辑、调试和重构功能。尽管使用简单的文本编辑器和命令行也可以完成大部分开发工作,但很少有人愿意这样做。然而,IDE却存在一些缺陷:

  • IDE依赖繁琐的手工操作。编译、测试、代码生成等任务相互独立,很难通过一键操作来完成所有工作,手动操作效率低下;
  • 在项目中统一所有的 IDE配置是很困难的。每个开发者都有自己的配置偏好,正是由于这个原因,一个在A机器上成功运行的任务,在B机器上的 IDE中可能会失败。

因此,我们应该合理利用IDE,而不是过度依赖它。对于构建这类任务,反复点击鼠标在 IDE中操作是不够智能的行为。Maven是在这方面专业的工具,并且主流的 IDE已经集成了Maven,因此我们可以在 IDE中方便地运行Maven进行构建操作。

2.2 Make

Make可能是最早的构建工具,由Stuart Feldman于1977年在贝尔实验室创建。由于这个贡献,他在2003年获得了ACM国际计算机组织颁发的软件系统奖。目前,Make有许多衍生实现,包括最流行的GNU MakeBSD Make,还有Windows平台上的Microsoft nmake等。

Make由一个名为 Makefile的脚本文件驱动,该文件使用Make定义的自己的语法格式。它的基本组成部分包括一系列规则(Rules),每条规则包括目标(Target)、依赖(Prerequisite)和命令(Command)。Makefile的基本结构如下:

target: prerequisitecommand

Make通过一系列目标和依赖将整个构建过程串联起来,并利用本地命令完成每个目标的实际操作。它的强大之处在于可以利用各种系统的本地命令,尤其是UNIX/Linux系统,这些功能丰富且强大的命令能够帮助 Make快速高效地完成任务。

然而,Make也存在一些限制:它将自己与操作系统绑定在了一起。换句话说,使用Make很难(至少较为困难)实现跨平台构建,对于Java来说,这非常不友好。此外,Makefile的语法也经常成为问题,很多人抱怨 Make构建失败的原因往往是由于难以察觉的空格或制表符(Tab)使用错误导致的。

2.3 Ant

Ant(Another Neat Tool)是一个构建工具,最初用于构建著名的 Tomcat 服务器。它的创作动机源于James Duncan Davidson 对 Makefile语法格式的不满。我们可以将Ant 视为Java版本的 Make,正因为使用了Java,Ant是跨平台的。此外,Ant使用XML来定义构建脚本,相对于Makefile来说更加友好。

类似于MakeAnt 也有一个构建脚本 build.xml,示例如下:

<?xml version="1.0"?>
<project name="Hello"	default="compile"><target name="compile" description="compile the Java source code to class files"><mkdir dir="classes'/><javac srcdir="." destdir="classes"/></target><target name="jar" depends="compile" description="create a Jar file"><jar destfile="hello,jar"><fileset dir="classes" includes="**/s.class"/><manifest><attribute name="Main-Class" value="HelloProgram"/></manifest></jar></target>
</project>

build.xml 的基本结构包括目标(target)、依赖(depends)以及实现目标的任务。例如,在上述脚本中,jar目标用于创建应用程序的 jar文件,该目标依赖于compile目标。compile目标执行的任务是在当前目录编译Java文件并将其输出到一个名为classes的文件夹中。当compile目标完成后,jar目标接着执行自己的任务。

Ant内置了大量用Java实现的任务,这确保了它的跨平台特性。此外,Ant 还提供了特殊的exec任务用于执行本地命令。

Make 一样,Ant 也都是过程式的,开发者显式地指定每一个目标,以及完成该目标所需要执行的任务。针对每一个项目,开发者都需要重新编写这一过程,这里其实隐含着很大的重复行为。 而Maven 是声明式的,项目构建过程和过程各个阶段所需的工作都由插件实现, 并且大部分插件都是现成的,开发者只需要声明项目的基本元素, Maven 就执行内置的、 完整的构建过程,这在很大程度上减少了重复性。

在过去的一段时间里,Ant 没有提供依赖管理功能,这意味着Ant用户不得不手动管理依赖关系,这是一个很麻烦的问题。幸运的是,现在Ant用户可以使用Ivy来管理依赖关系。对于Maven用户来说,依赖管理是最基本的,因为Maven内置了强大的依赖管理功能。此外,Maven还拥有一个中央仓库,可能是全世界最大的Java开源软件包集合,因此Maven用户无需进行任何配置即可直接享受依赖管理的好处。

2.4 Jenkins

图2 Jenkins的logo

Jenkins是一个开源的自动化工具,用于构建、测试和部署软件项目。它提供了一种简单且可扩展的方式来设置和管理软件交付流程。

相比于Maven,Jenkins更加强大且灵活。通过使用Jenkins,你可以在软件开发过程中自动化执行各种任务和工作流程,并监视其执行情况。下面是一些Jenkins的核心功能:

  1. 自动化构建和持续集成:Jenkins允许你在代码提交后自动触发构建过程,并检查代码质量、运行单元测试等。这有助于减少手动操作和加快构建发布周期。

  2. 插件生态系统:Jenkins拥有丰富的插件生态系统,使你可以轻松地扩展其功能。这些插件包括与其他工具的集成、生成报告、发送通知等。例如,你可以使用Maven插件将Maven生成的结果集成到Jenkins中并展示。

  3. 流水线管理:Jenkins支持基于流水线的软件交付流程定义和管理。使用Jenkins Pipeline插件,你可以以可编程的方式定义整个交付流程,包括构建、测试、部署和回滚等步骤。

  4. 可视化报告:Jenkins能够将各个阶段的结果以图表的形式展示出来,包括构建情况、测试覆盖率、代码质量等。这使得开发人员和项目经理可以更方便地查看和分析项目的状态和趋势。

通过Jenkins,你可以实现更高效的软件交付过程,并为团队提供实时可视化的项目状态信息。它提供了一个集中化的平台,以管理和执行各种工作流程,节省了配置和维护不同工具之间的复杂性。

本专栏主要介绍Maven,那么对于同样重要的 Jenkins技术,后续我会专门做一个专栏做更详细的知识介绍,请大家持续关注。

3️⃣ Maven与敏捷开发

首先需要了解,敏捷开发(Agile Development)是一种软件开发方法理论,旨在通过迭代、协作和灵活性来应对变化的需求。它强调快速响应变更、频繁交付可工作的软件以及与客户紧密合作等核心原则。

而极限编程(Extreme Programming)则是敏捷开发中一种具体的实践方法之一,其目标是提供高质量的软件解决方案,并通过团队合作和持续反馈来增加生产效率。极限编程强调快速迭代、自动化测试、简单设计、持续集成以及面向人员的价值观等重要实践。

下面看一下 Maven 是如何适应极限编程的。

  • 简单性。Maven 暴露了一组一致且简洁的操作接口,能帮助团队成员从原来高度自定义的、复杂的构建系统中解脱出来,使用Maven 现有的成熟稳定的组件,也能简化构建系统的复杂度;
  • 交流与反馈。与版本控制系统结合后,所有人都能执行最新的构建并快速得到反馈。此外,自动生成的项目报告也能帮助成员了解项目的状态,促进团队的交流;
  • 测试驱动开发 (TDD)。TDD 强调测试先行,所有产品都应该由测试用例覆盖。而测试是Maven 生命周期的最重要的组成部分之一,并且 Maven 有现成的成熟插件支持 业界流行的测试框架,如 JUnitTestNG
  • 快速构建。快速构建强调我们能够随时快速地从源码构建出最终的产品。这正是Maven 所擅长的,只需要一些配置,之后用一条简单的命令就能让 Maven 帮你清理、编译、测试、打包、部署,然后得到最终的产品;
  • 持续集成 (CI) 。CI 强调项目以很短的周期(如15分钟)集成最新的代码。实际上, CI 的前提是源码管理系统和构建系统。流行的CI 服务器如 HudsonCruiseControl 都能很好地和 Maven 进行集成。也就是说,使用Maven 后,持续集成会变得更加方便;
  • 富有信息的工作区。强调开发者能够快速方便地了解到项目的最新状态。 当然, Maven 并不会帮你把测试覆盖率报告贴到墙上,也不会在你的工作台上放个鸭子告诉你构建失败了。不过使用Maven 发布的项目报告站点,并配置你需要的项目报告,如测试覆盖率报告,都能帮你把信息推送到开发者眼前。

上述这些实践并非只在极限编程中适用。事实上,除了其他敏捷开发方法如 SCRUM 之外,几乎任何软件开发方法都能借鉴这些实践。也就是说, Maven 几乎能够很好地支持任何软件开发方法。

例如,在传统的瀑布模型开发中,项目依次要经历需求开发、分析、设计、编码、测试和集成发布阶段。从设计和编码阶段开始,就可以使用 Maven 来建立项目的构建系统。 在设计阶段,也完全可以针对设计开发测试用例,然后再编写代码来满足这些测试用例。 然而,有了自动化构建系统,我们可以节省很多手动的测试时间。此外,尽早地使用构建系统集成团队的代码,对项目也是百利而无一害。最后, Maven 还能帮助我们快速地发布项目。

🌾 总结

本文从概念上简单地介绍了一下Maven, 通过本章我们应该能大致了解Maven 是什么以及它有什么用途。我们还将Maven 与其他流行的构建工具(如Make 和 Ant等) 做了一些对比分析。如果你没用过Maven, 但有Make 或者 Ant 的使用经验,相信通过比较你能更清楚地了解各种工具的优劣势,并且会对Maven 有一个理性的认识。

将 Maven 和敏捷开发与极限编程结合起来分析是为了让大家从另 一个角度了解Maven, 毕竞软件开发离不开对于软件过程的理解。希望大家积极理解 Maven并从中受益。


继续阅读下一篇(点击跳转)
《》

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/96098.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【解决】Kafka Exception thrown when sending a message with key=‘null‘ 异常

问题原因&#xff1a; 如下图&#xff0c;kafka 中配置的是监听域名的方式&#xff0c;但程序里使用的是 ip:port 的连接方式。 解决办法&#xff1a; kafka 中配置的是域名的方式&#xff0c;程序里也相应配置成 域名:port 的方式&#xff08;注意&#xff1a;本地h…

Excelize Go语言操作 Office Excel文档基础库

Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库&#xff0c;基于 ECMA-376&#xff0c;ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格文档。支持 XLAM / XLSM / XLSX / XLTM / XLTX 等多种文档格式&#xf…

【.net】本地调试运行只能用localhost的问题

【.net】本地调试运行只能用localhost的问题 解决方案 找到到项目目录下 隐藏文件夹 .vs /项目名称/config/applicationhost.config <bindings><binding protocol"http" bindingInformation"*:1738:localhost" /></bindings> 再加一条你…

大数据面试题:Spark的任务执行流程

面试题来源&#xff1a; 《大数据面试题 V4.0》 大数据面试题V3.0&#xff0c;523道题&#xff0c;679页&#xff0c;46w字 可回答&#xff1a;1&#xff09;Spark的工作流程&#xff1f;2&#xff09;Spark的调度流程&#xff1b;3&#xff09;Spark的任务调度原理&#xf…

国产之光:讯飞星火最新大模型V2.0

大家好&#xff0c;我是herosunly。985院校硕士毕业&#xff0c;现担任算法研究员一职&#xff0c;热衷于机器学习算法研究与应用。曾获得阿里云天池比赛第一名&#xff0c;CCF比赛第二名&#xff0c;科大讯飞比赛第三名。拥有多项发明专利。对机器学习和深度学习拥有自己独到的…

ICCV23 | Ada3D:利用动态推理挖掘3D感知任务中数据冗余性

​ 论文地址&#xff1a;https://arxiv.org/abs/2307.08209 项目主页&#xff1a;https://a-suozhang.xyz/ada3d.github.io/ 01. 背景与动因 3D检测(3D Detection)任务是自动驾驶任务中的重要任务。由于自动驾驶任务的安全性至关重要(safety-critic)&#xff0c;对感知算法的延…

python爬虫7:实战1

python爬虫7&#xff1a;实战1 前言 ​ python实现网络爬虫非常简单&#xff0c;只需要掌握一定的基础知识和一定的库使用技巧即可。本系列目标旨在梳理相关知识点&#xff0c;方便以后复习。 申明 ​ 本系列所涉及的代码仅用于个人研究与讨论&#xff0c;并不会对网站产生不好…

Java-运算符和控制语句(上)(基于c语言的补充)

算术运算符 关于求余 不管分子&#xff0c;分母是正还是负&#xff0c;对于分母&#xff0c;直接取正&#xff1b;对于分子若有负号&#xff0c;则先提取出来&#xff1b;剩下两个正的分子分母运算&#xff1b;最后&#xff0c;若刚才的分子有负号&#xff0c;对最后的结果添加…

C语言刷题训练DAY.8

1.计算单位阶跃函数 解题思路&#xff1a; 这个非常简单&#xff0c;只需要if else语句即可完成 解题代码&#xff1a; #include <stdio.h>int main() {int t 0;while(scanf("%d",&t)!EOF){if (t > 0)printf("1\n");else if (t < 0)pr…

Unity UI内存泄漏优化

项目一运行&#xff0c;占用的内存越来越多&#xff0c;不会释放&#xff0c;导致GC越来越频繁&#xff0c;越来越慢&#xff0c;这些都是为什么呢&#xff0c;今天从UI方面谈起。 首先让我们来聊聊什么是内存泄漏呢&#xff1f; 一般来讲内存泄漏就是指我们的应用向内存申请…

最新k8s集群搭建教程

本次安装在vmware虚拟机下开启3台2核2g的Ubuntu20.04系统 master&#xff1a;192.168.192.137 node1&#xff1a;192.168.192.136 node2&#xff1a;192.168.192.138 关闭防火墙 先查看防火墙状态&#xff0c;如果是关闭就不用管 ufw status关闭selinux&#xff0c;如果没有安…

SystemVerilog interface使用说明

1. Interface概念 System Verilog中引入了接口定义&#xff0c;接口与module 等价的定义&#xff0c;是要在其他的接口、module中直接定义&#xff0c;不能写在块语句中&#xff0c;跟class是不同的。接口是将一组线捆绑起来&#xff0c;可以将接口传递给module。 2. 接口的优…

JAVA免杀学习与实验

1 认识Webshell 创建一个JSP文件&#xff1a; <% page import"java.io.InputStream" %> <% page import"java.io.BufferedReader" %> <% page import"java.io.InputStreamReader" %> <% page language"java" p…

python的全局解释锁(GIL)

一、介绍 全局解释锁&#xff08;Global Interpreter Lock&#xff0c;GIL&#xff09;是在某些编程语言的解释器中使用的一种机制。在Python中&#xff0c;GIL是为了保证解释器线程安全而引入的。 GIL的作用是在解释器的执行过程中&#xff0c;确保同一时间只有一个线程可以…

JVM——引言+JVM内存结构

引言 什么是JVM 定义: Java VirtualMachine -java 程序的运行环境 (ava 二进制字节码的运行环境) 好处: 一次编写&#xff0c;到处运行自动内存管理&#xff0c;垃圾回收功能数组下标越界检查&#xff0c;多态 比较: jvm jre jdk 学习jvm的作用 面试理解底层实现原理中…

目标检测(Object Detection)

文章目录 1. 目标检测1.1 目标检测简要概述及名词解释1.2 IOU1.3 TP TN FP FN1.4 precision&#xff08;精确度&#xff09;和recall&#xff08;召回率&#xff09; 2. 边框回归Bounding-Box regression3. Faster R-CNN3.1 Faster-RCNN&#xff1a;conv layer3.2 Faster-RCNN&…

Photoshop制作漂亮光泽感3D按钮

原文链接(https://img-blog.csdnimg.cn/45472c07f29944458570b59fe1f9a0e0.png)

直线导轨的选购要素

直线导轨是用来支撑和引导运动部件&#xff0c;按给定的方向做往复直线运动&#xff0c;主要用于精密机床、坐标测量机和大型机床&#xff0c;对于我们整个国民生产、生活活动都起着至关重要的作用。 我们在选购直线导轨时&#xff0c;都想要选到质量好的&#xff0c;那么我们要…

手把手教学——终端工具xshell与文件传输工具xftp使用步骤及详解

前言 xshell是一款常用于连接本地linux服务以及云服务器的终端远程连接工具&#xff0c;该款终端工具常搭配远程文件传输工具xftp一起使用&#xff0c;由于还有很多小伙伴还不知道这两款终端工具的使用流程及步骤&#xff0c;Darren洋在这里给小伙伴们进行详细讲解。 一、下载工…

慎用!澳洲留学生用ChatGPT写论文被控学术不端!AI论文漏洞百出,各高校已加强捡测!

自从进入ChatGPT时代以来&#xff0c;留学生们纷纷表示写作业&#xff0c;so easy。留学生们在用AI写论文时候没有预计到的是&#xff0c;ChatGPT存在杜撰文献的问题&#xff0c;并且学校已经在使用AI检测工具。 目前全澳大多数大学都可以选择使用现在很流行的反剽窃软件服务T…