Maven高级操作--分模块设计、聚合、继承和私服

news/2024/11/7 23:37:33/

一、分模块设计与开发

1.1 分模块设计

  • 问题:当项目做大做强的时候,前面的基础Spring开发的框架都无法满足java大型项目的维护和复用,而且团队合作也会造成较大的困难。
  • 所以就需要分模块设计:将项目按照功能拆分成若干个子模块,方便项目的管理维护扩展,也方便模块间的相互调用资源共享

分模块开发需要先针对模块功能进行设计,再进行编码。不会先将工程开发完毕,然后进行拆分。

  • 大概步骤:
  1. 创建一个新的maven项目,并填写需要分出去的模块名。
  2. 在原项目下将模块的包,如utils包下的类,放到目标maven项目下,目录名字保持一致main\java\com\mannor\utlis
  3. 将需要的依赖项导入到新maven中。
  4. 将新maven导入到原来的项目pom.xml文件中,即可食用。

二、继承与聚合

2.1 继承

  • 概念:继承描述的是两个工程间的关系,与java中的继承相似,子工程*可以继承父工程中的配置信息,常见于依赖关系的继承**。
  • 作用:简化依赖配置、统一管理依赖
  • 实现:<parent> ... </parent>

2.1.1 继承关系的实现

  1. 创建maven模块tlias-parent,该工程为父工程,设置打包方式**pom**(默认jar)。
    <!-- 只截取了关键部分代码 --><!-- 设置父工程 --><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.7.12</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.mannor</groupId><artifactId>tlias-parent</artifactId><version>0.0.1-SNAPSHOT</version><packaging>pom</packaging> <!-- 设置打包方式 --></project>
  1. 子工程pom.xml文件中,配置继承关系。
    <!-- 只截取了关键部分代码 --><parent><groupId>com.mannor</groupId><artifactId>tlias-parent</artifactId><version>0.0.1-SNAPSHOT</version><relativePath>../tlias-parent/pom.xml</relativePath> <!-- 父工程的pom文件的相对路径 --></parent><artifactId>tlias-web-management</artifactId><version>0.0.1-SNAPSHOT</version><name>tlias-web-management</name><description>tlias-web-management</description>
  1. 父工程中配置各个工程共有的依赖(子工程会自动继承父工程的依赖)。
  • 代码展示略。

2.1.1.1 继承关系图

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-a6mOZ6ev-1688110403571)(24_files/1.jpg)]

2.1.1.2 重点

  1. 在子工程中,配置了继承关系之后,坐标中的groupId是可以省略的,因为会自动继承父工程的。
  2. relativePath指定父工程的pom文件的相对位置(如果不指定,将从本地仓库/远程仓库查找该工程)。
  3. 若父子工程都配置了同一个依赖的不同版本,以子工程的为准。

常见的打包方式:
jar:普通模块打包,springboot项目基本都是jar包(内嵌tomcat运行)
war:普通web程序打包,需要部署在外部的tomcat服务器中运行
pom:父工程或聚合工程,该模块不写代码,仅进行依赖管理

2.1.2 版本锁定

2.1.2.1 版本管理

  • 在maven中,可以在父工程的pom文件中通过<dependencyManagement>来统一管理依赖版本。
  • 子工程引入依赖时,无需指定<version>版本号,父工程统一管理。变更依赖版本,只需在父工程中统一变更。
  1. 在父工程中:
 <!--  统一管理依赖版本:只是版本的管理,不会有直接依赖 --><dependencyManagement><dependencies><!--  jwt令牌--><dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt</artifactId><version>0.9.1</version></dependency></dependencies></dependencyManagement>
  1. 在子工程中直接引用即可,无需指定版本号:
    <dependencies> <!--  jwt令牌--><dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt</artifactId></dependency></dependencies>

2.1.2.2 自定义属性/引用属性

  • 在大型开发中,会有许多依赖需要引用,所以有自定义属性来直接管理版本信息,更方便后期的维护。
  1. 自定义属性:
    <properties><lombok.version>1.18.24</lombok.version></properties>
  1. 引用属性
    <dependencies><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>${lombok.version}</version></dependency></dependencies>

思考?<dependencyManagement><dependencies>的区别是什么?
1.<dependencies>是直接依赖,在父工程配置了依赖,子工程会直接继承下来。
2.<dependencyManagement>`是统一管理依赖版本,不会直接依赖,还需要在子工程中引入所需依赖(无需指定版本)

2.2 聚合

  • 当项目开发完毕时,要对目标工程执行打包的操作。目标工程会在本地的maven仓库中去寻找对应依赖的jar包,不然就不会构建成功。
  • 要想将jar包放到maven的本地仓库就要按照顺序执行对应maven项目或者模块的install操作,这样才会打包成功。

当然这种方式的缺点也很明显,就是当项目模块的数量很多的时候就不便于操作了。所以就需要maven的聚合。

2.2.1 概念

2.2.1.1 聚合:

  • 将多个模块组织成一个整体,同时进行项目的构建。

2.2.1.2 聚合工程

  • 一个不具有业务功能的“空”工程(有且仅有一个pom文件)---->parent父工程就刚好可以充当这样得到角色。

2.2.1.3. 作用

  • 快速构建项目(无需根据依赖关系手动构建,直接在聚合工程上构建即可)

2.2.2 操作实现

  • maven中可以通过<modules>设置当前聚合工程所包含的子模块名称

聚合工程中所包含的模块,在构建时,会自动根据模块间的依赖关系设置构建顺序,与聚合工程中模块的配置书写位置无关。

  • 源码实现,在父工程的pom.xml文件下:
    <!--  聚合其他模块  --><modules><module>../tlias-pojo</module>   <!-- 在里面填写需要聚合模块的相对路径 --><module>../tlias-utlis</module><module>../tlias-web-management</module></modules>
  • 最后操作:执行父工程的install或clean等指令和程序。

2.3 继承与聚合的区别

2.3.1 作用

  • 聚合用于快速构建项目
  • 继承用于简化依赖配置、统一管理依赖

2.3.2 相同点:

  • 聚合与继承的pom.xml文件打包方式均为pom,可以将两种关系制作到同一个pom文件中聚合与继承均属于设计型模块,并无实际的模块内容

2.3.3 不同点:

  • 聚合是在聚合工程中配置关系,聚合可以感知到参与聚合的模块有哪些继承是在子模块中配置关系,父模块无法感知哪些子模块继承了自己

三、maven的私服

1.介绍

  • 私服是一种特殊的远程仓库,它是架设在局域网内的仓库服务,用来代理位于外部的中央仓库,用于解决团队内部的资源共享与资源同步问题。
  • 依赖查找顺序:–>本地仓库–>私服–>中央仓库

私服在企业项目开发中,一个项目/公司,只需要一台即可(无需我们自己搭建,会使用即可)。

2.资源的上传和下载

  • 项目版本:
    • RELEASE(发行版本)︰功能趋于稳定、当前更新停止,可以用于发行的版本,存储在私服中的RELEASE仓库中。
    • SNAPSHOT(快照版本)︰功能不稳定、尚处于开发中的版本,即快照版本,存储在私服的SNAPSHOT仓库

3.具体操作

  1. 设置私服的访问用户名/密码(settings.xml中的servers中配置)。
  2. IDEA的maven工程的pom文件中配置上传(发布)地址。
  3. 设置私服依赖下载的仓库组地址(settings.xml中的mirrors、profiles中配置。

因为私服的信息配置都是固定的步骤,所以我将私服的配置操作在此省略,单独写成md文件,需要的可以私我发你。


http://www.ppmy.cn/news/665132.html

相关文章

SpringBoot3之GraalVM之Windows详细安装及使用教程

配置Maven环境变量 我直接使用的是IDEA plugins文件夹下的maven 新建MAVEN_HOME环境变量 Path环境变量追加 %MAVEN_HOME%\bin安装Visual Studio Community 因为GraalVM需要调用操作系统的底层工具&#xff0c;而Windows底层工具是VisualStudio&#xff0c;所以我们要先下载…

在上海做什么赚钱快?这10个你可以试一试!

现在生活压力越来越大&#xff0c;工作也越来越难找&#xff0c;尤其是想找一个各方面都比较合适的更是难上加难&#xff0c;因此&#xff0c;很多人就选择在家创业&#xff0c;那么在家创业都干什么比较赚钱呢?在上海做什么赚钱快&#xff1f;这10个你可以试一试&#xff01;…

关于Jetpack DataStore(Proto)的六点疑问

前言 上篇分析了DataStore(Preferences)的使用与原理&#xff0c;本篇接着阐述DataStore的另一种实现形式&#xff1a;DataStore(Proto)。 通过本篇文章&#xff0c;你将了解到&#xff1a; 1. 为什么需要Proto&#xff1f; DataStore(Preferences)对标SharedPreferences&a…

使用Node.js开发服务器进行请求转发和CORS处理

在Web开发过程中&#xff0c;我们经常会遇到需要在前端应用中与不同的API或后端服务进行通信的情况。然而&#xff0c;由于浏览器的同源策略限制&#xff0c;跨域请求会受到CORS&#xff08;跨域资源共享&#xff09;策略的限制。为了解决这个问题&#xff0c;我们可以使用Node…

QQ天气H5-前端完整解析

前言&#xff1a; 什么是手Q天气 手Q天气是在手Q 6.0版本以上新增的功能&#xff0c;页面会展现当天的气温情况&#xff0c;已经五天温度折线图以及24小时温度图表等。 并且为了更好的交互效果&#xff0c;天气页面会根据8种不同的天气信息&#xff0c;展现相应的天气动画。 如…

Hive(17):Hive Show显示语法

Show相关的语句提供了一种查询Hive metastore的方法。可以帮助用户查询相关信息。 1 显示所有数据库 SCHEMAS和DATABASES的用法 功能一样 show databases; show schemas; 2 显示当前数据库所有表/视图/物化视图/分区/索引 show tables; SHOW TABLES [IN database_name]; --指…

HTML5怎样解决PC端多屏适配问题,如何让页面适配各种机型

我们可以知道,页面主体中规中矩,分为两部分:上半部分是介绍页面,下半部分是主体界面,有一个点击按钮来负责全部用户交互,为了适配iphone4到6plus以及众多安卓,我们对整个页面的架构可以有如下几种方案: 01- 高度百分比 高度百分比方案——整个屏幕的主要高度高度都用百…

android 老人模式吗,父母适合用安卓还是iPhone?看完这些适老化功能再做决定

原标题&#xff1a;父母适合用安卓还是iPhone&#xff1f;看完这些适老化功能再做决定 选智能手机是个大事&#xff0c;毕竟生活中各种场景都要用到。年轻人选手机考虑的方方面面比较多&#xff0c;既要有好看的外观&#xff0c;在性能、功能、系统等里里外外都要兼顾到。可现如…