博客
关于我
Maven之——坐标和依赖(上)
阅读量:429 次
发布时间:2019-03-06

本文共 1624 字,大约阅读时间需要 5 分钟。

Maven坐标和依赖(上)

在软件开发领域,Maven作为一个领先的项目管理工具,拥有强大的依赖管理功能。理解Maven坐标和依赖的工作原理,是掌握Maven项目管理的重要基础。本文将从坐标的概念、具体解释以及依赖配置等方面,带你深入了解Maven的核心机制。

Maven坐标概念

Maven通过坐标(Coordinates)来定位和管理项目及其依赖。项目坐标由以下几个核心元素组成:groupId、artifactId、version、packaging和classifier。这些元素共同构成了项目的唯一标识。在Maven仓库中,项目坐标决定了构件的存储位置。需要注意的是,Maven内置了默认的仓库地址,如果需要自定义仓库位置,可以在Maven的配置文件中进行设置。

Maven坐标具体解释

项目坐标的每个元素都有其特定的含义:

  • groupId:定义项目所属的组织或项目群组。例如,org.andy.items 表示该项目隶属于组织 "Andy" 的 "Items" 项目组。
  • artifactId:定义项目中的具体模块或构件。例如,scattered-items 表示 "Items" 项目组下的一个具体模块。
  • version:指定项目的版本号。例如,1.0-SNAPSHOT 表示项目当前处于快照版本。
  • packaging:定义构件的打包格式,默认为 jar。如果项目打包为 war,则构件名称会以 .war 结尾。
  • classifier:用于定义构件的附属品。例如,sources 用于源代码构件,javadoc 用于Javadoc文档构件。

需要注意的是,groupId、artifactId和version是必填字段,packaging是可选的(默认为jar),而classifier不能直接定义,通常由插件自动生成。

依赖配置

在Maven项目中,依赖关系通过 <dependencies> 元素来配置。每个依赖可以包含以下元素:

  • groupId:依赖项目的组织或项目群组。
  • artifactId:依赖项目的具体模块或构件。
  • version:依赖项目的版本号。
  • scope:指定依赖的范围,默认为 compile
  • type:指定依赖的类型,默认为 jar
  • optional:标记是否为可选依赖。
  • exclusions:指定需要排除的依赖。

一个完整的依赖配置示例如下:

org.springframework
spring-context
4.1.2.RELEASE
runtime

上述配置表示项目依赖了Spring Framework的 spring-context 组件,其版本为4.1.2.RELEASE,且仅在编译和执行阶段生效。

依赖范围

Maven的依赖范围(dependency scopes)决定了依赖在不同阶段的有效性。常见的依赖范围包括:

  • compile:默认范围,依赖在编译、测试和执行阶段都有效。
  • test:仅在测试阶段生效,例如Junit。
  • provided:在编译和测试阶段生效,但不需要在执行阶段提供。例如,servlet-api 通常由容器提供。
  • runtime:仅在执行和测试阶段生效,例如JDBC驱动。
  • system:与 provided 范围类似,但需要手动指定依赖路径。
  • import:用于与 dependencyManagement 结合使用,不影响类路径。

理解这些范围有助于优化项目依赖,减少不必要的依赖下载和构建时间。

通过上述内容的学习,你已经对Maven坐标和依赖有了初步的了解。接下来,建议你通过实践项目配置,逐步掌握这些概念的应用。

转载地址:http://kfruz.baihongyu.com/

你可能感兴趣的文章
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>
NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
查看>>
NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>
NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
查看>>
NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
查看>>
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
查看>>