javaWeb从入门到进阶(maven高级进阶)

目录

Maven多模块项目设计与原理

[1. 模块化架构思想](#1. 模块化架构思想)

[2. 典型模块划分方式](#2. 典型模块划分方式)

[3. 设计原则](#3. 设计原则)

Maven的继承与聚合

继承

继承关系实现

版本锁定

聚合

继承与聚合的比较

私服


前言:我们前面所写的案例是基于springboot构建的单体项目,所有的代码都混在一起,所有的依赖都在同一个xml文件中,难以识别哪些模块需要哪些依赖,同时,每次构建都是全量构建,效率低下。而随着业务需求的推进,原始的单体架构难以维持需求,因而推出了maven多模块,由原始的一个项目演变成多个项目关联,每个模块实现特定的功能,需要什么就引入特定的依赖。

Maven多模块项目设计与原理

1. 模块化架构思想

  • 分层设计:将大型项目拆分为多个相互关联的模块

  • 关注点分离:每个模块负责特定功能领域

  • 依赖管理:明确模块间的依赖关系,避免循环依赖

2. 典型模块划分方式

复制代码
parent-project(聚合模块)
├── pom.xml(父POM)
├── common(公共模块)
├── domain(领域模型)
├── service(业务服务)
├── dao(数据访问)
├── web(Web接口)
└── app(启动模块)

3. 设计原则

  • 单一职责:每个模块只承担一个明确定义的功能

  • 高内聚低耦合:模块内部高度相关,模块间依赖最小化

  • 依赖传递控制 :合理使用<dependencyManagement>管理版本

  • 继承与聚合分离:区分父模块(继承)和聚合

Maven多模块设计通过继承和聚合机制,实现了项目的模块化、标准化管理。它不仅解决了大型项目的代码组织问题,还通过统一的依赖管理和构建配置,提高了开发效率和维护性。正确的多模块设计能够使项目结构更清晰、构建更高效、依赖更可控,是现代Java项目开发的必备实践。

前言:在实施maven的多模块开发时,我们发现,即便是不同的模块,有事也会用到同一个依赖,然而我们仍需在每个模块中依次引入对应的依赖,这时就显得较为繁琐。

Maven的继承与聚合

继承

概念:继承描述的是两个工程间的关系,与java中的继承相似,子工程可以继承父工程中的配置信息,常见于依赖关系的继承。

作用:简化依赖配置、统一管理依赖

实现:<parent>...</parent>

继承关系实现

1.创建maven模块tlias-parent,该工程为父工程,设置打包方式pom(默认jar)。

2.在子工程的pom.xml文件中,配置继承关系。

3.在父工程中配置各个工程共有的依赖(子工程会自动继承父工程的依赖)

注意事项:

在子工程中,配置了继承关系之后,坐标中的groupId是可以省略的,因为会自动继承父工程的。

relativePath指定父工程的pom文件的相对位置(如果不指定,将从本地仓库/远程仓库查找该工程)。

版本锁定

在maven中,可以在父工程的pom文件中通过<dependencyManagement>来统一管理依赖版本。

注意事项

子工程引入依赖时,无需指定<version>版本号,父工程统一管理。变更依赖版本,只需在父工程中统一变更。

面试题:

<dependencyManagement> 与 <dependencies>的区别是什么?

<dependencies>是直接依赖,在父工程配置了依赖,子工程会直接继承下来。<dependencyManagement>是统一管理依赖版本,不会直接依赖,还需要在子工程中引入所需依赖(无需指定版本)

聚合

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

聚合工程(父工程)

一个不具有业务功能的"空"工程(有且仅有一个pom文件)

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

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

继承与聚合的比较

聚合用于快速构建项目
继承用于简化依赖配置、统一管理依赖相同点:
聚合与继承的pom.xml文件打包方式均为pom,可以将两种关系制作到同一个pom文件中聚合与继承均属于设计型模块,并无实际的模块内容不同点:
聚合是在聚合工程中配置关系,聚合可以感知到参与聚合的模块有哪些继承是在子模块中配置关系,父模块无法感知哪些子模块继承了自己

私服

私服是一种特殊的远程仓库,它是架设在局域网内的仓库服务,用来代理位于外部的中央仓库,用于解决团队内部的资源共享与资源同步问题。

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

资源的上传和下载:

项目版本:

RELEASE(发行版本):功能趋于稳定、当前更新停止,可以用于发行的版本,存储在私服中的RELEASE仓库中。

SNAPSHOT(快照版本):功能不稳定、尚处于开发中的版本,即快照版本,存储在私服的SNAPSHOT仓库中。

步骤;

相关推荐
勇往直前plus4 小时前
从文件到屏幕:Python/java 字符编码、解码、文本处理的底层逻辑解析
java·开发语言·python
Drifter_yh10 小时前
【黑马点评】Redisson 分布式锁核心原理剖析
java·数据库·redis·分布式·spring·缓存
莫寒清12 小时前
Spring MVC:@RequestParam 注解详解
java·spring·mvc
没有医保李先生12 小时前
字节对齐的总结
java·开发语言
甲枫叶14 小时前
【claude】Claude Code正式引入Git Worktree原生支持:Agent全面实现并行独立工作
java·人工智能·git·python·ai编程
六件套是我14 小时前
无法访问org.springframeword.beans.factory.annotation.Value
java·开发语言·spring boot
LYS_061814 小时前
C++学习(5)(函数 指针 引用)
java·c++·算法
forestsea15 小时前
Spring Cloud Alibaba 2025.1.0.0 正式发布:拥抱 Spring Boot 4.0 与 Java 21+ 的新时代
java·spring boot·后端
IT枫斗者15 小时前
IntelliJ IDEA 2025.3史诗级更新:统一发行版+Spring Boot 4支持,这更新太香了!
java·开发语言·前端·javascript·spring boot·后端·intellij-idea