Spring Boot 项目中 Maven 剔除无用 Jar 引用的最佳实践
目录
- 引言
- Maven 依赖管理的基础概念
- 2.1 什么是 Maven 依赖
- 2.2 Maven 的依赖传递机制
- 无用依赖的常见问题与影响
- 剔除无用 Jar 引用的常见方法
- 4.1 识别无用依赖
- 4.2 使用 Maven 的
dependency:analyze插件 - 4.3 配置
scope以优化依赖范围 - 4.4 使用
exclude排除传递依赖 - 4.5 分析依赖树
- 最佳实践:一步步清理无用 Jar
- 5.1 基础清理方法
- 5.2 高级清理方法
- 5.3 自动化剔除
- Spring Boot 特有的优化策略
- 总结与展望
引言
在 Spring Boot 项目开发中,Maven 是最常用的构建工具之一。通过 Maven,我们可以轻松地管理项目所需的依赖。然而,随着项目的复杂化,无用的 Jar 包引用可能会逐渐增多,导致构建时间延长、运行效率下降,甚至引发潜在的依赖冲突问题。
本文旨在详细解析如何在 Spring Boot 项目中剔除无用的 Jar 引用,并提供一套系统化的清理和优化方法,帮助开发者构建高效、清晰、轻量化的项目依赖管理体系。
Maven 依赖管理的基础概念
2.1 什么是 Maven 依赖
Maven 依赖是指项目所需的第三方库,通常以 Jar 文件的形式存储在 Maven 仓库中。每个 Maven 项目都有一个 pom.xml 文件,用于声明这些依赖。例如:
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><version>3.0.0</version>
</dependency>
通过 Maven 的依赖管理功能,可以自动下载并配置这些库。
2.2 Maven 的依赖传递机制
Maven 支持依赖传递机制,即一个依赖可能会自动引入其他依赖。这些通过传递引入的依赖称为“传递依赖”。例如:
- 项目 A 引入了依赖 B
- 依赖 B 又引入了依赖 C
- 那么项目 A 将自动拥有 B 和 C 的功能。
依赖传递可以显著提高开发效率,但也容易导致以下问题:
- 引入不必要的依赖。
- 版本冲突。
- 增加构建时间。
无用依赖的常见问题与影响
3.1 无用依赖的来源
- 默认依赖:Spring Boot 的
starter通常包含很多默认依赖,部分功能可能未使用。 - 传递依赖:引入的第三方库中可能包含无关的传递依赖。
- 历史遗留:项目早期引入的依赖可能已经不再需要,但仍然存在于
pom.xml中。
3.2 无用依赖的影响
- 构建时间变长:无用依赖会增加编译和打包的时间。
- 运行效率下降:无用的 Jar 包会占用内存和资源,影响运行效率。
- 潜在冲突:不必要的依赖可能会与核心依赖版本不一致,导致运行时错误。
剔除无用 Jar 引用的常见方法
4.1 识别无用依赖
最基础的方法是手动检查 pom.xml 文件,找出那些不再使用的依赖。这需要对项目的实际代码和功能有深入了解。
4.2 使用 Maven 的 dependency:analyze 插件
Maven 提供了一个内置的 dependency:analyze 插件,可以分析项目中实际使用的依赖,并报告未使用的依赖。例如:
mvn dependency:analyze
运行结果中会显示:
- Used undeclared dependencies:未声明但已使用的依赖。
- Declared unused dependencies:声明但未使用的依赖。
示例输出:
[WARNING] Unused declared dependencies found:
[WARNING] org.apache.commons:commons-lang3:jar:3.12.0:compile
4.3 配置 scope 以优化依赖范围
通过指定依赖的作用范围(scope),可以限制依赖的可见性。例如:
compile:默认范围,编译时可见。provided:运行时不打包,仅在编译和测试时可见。runtime:运行时可见,但编译时不可见。test:仅在测试时可见。
示例:
<dependency><groupId>javax.servlet</groupId><artifactId>javax.servlet-api</artifactId><version>4.0.1</version><scope>provided</scope>
</dependency>
4.4 使用 exclude 排除传递依赖
可以通过 exclude 标签排除不需要的传递依赖。例如:
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><exclusions><exclusion><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-tomcat</artifactId></exclusion></exclusions>
</dependency>
4.5 分析依赖树
Maven 的 dependency:tree 命令可以列出项目的完整依赖树,帮助开发者清晰地看到所有依赖及其来源:
mvn dependency:tree
示例输出:
[INFO] +- org.springframework.boot:spring-boot-starter-web:jar:2.6.6:compile
[INFO] | \- org.springframework.boot:spring-boot-starter-tomcat:jar:2.6.6:compile
[INFO] +- org.apache.commons:commons-lang3:jar:3.12.0:compile
最佳实践:一步步清理无用 Jar
5.1 基础清理方法
- 定期检查依赖:使用
dependency:analyze和dependency:tree工具分析依赖。 - 清理历史遗留依赖:移除项目中不再使用的依赖。
- 避免不必要的
starter:按需引入 Spring Boot 的starter,避免默认引入未使用的模块。
5.2 高级清理方法
- 精简传递依赖:明确需要的传递依赖,排除多余的依赖项。
- 分模块管理依赖:对于多模块项目,可以通过父子 POM 统一管理依赖,减少重复定义。
5.3 自动化剔除
借助工具如 Maven Enforcer Plugin 或 Dependabot,可以自动检测无用依赖并提出优化建议。例如:
<plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-enforcer-plugin</artifactId><version>3.0.0</version><executions><execution><id>enforce-no-unused-dependencies</id><phase>validate</phase><goals><goal>enforce</goal></goals></execution></executions>
</plugin>
Spring Boot 特有的优化策略
- 精确控制
starter:根据项目需求选择starter,避免引入多余模块。 - 使用自定义依赖:将常用依赖打包成自定义
starter,统一管理和优化依赖。 - 定期更新依赖:Spring Boot 的每次更新都会优化其
starter的默认依赖,跟进最新版本可以减轻冗余依赖。
总结与展望
Maven 的依赖管理是 Spring Boot 项目构建的重要环节,合理清理无用的 Jar 引用,可以显著提高项目的构建效率和运行性能
。通过本文的系统讲解,相信开发者能够更好地掌握依赖优化的方法,构建一个高效、清晰、可维护的项目结构。
未来,随着工具和技术的不断发展,依赖优化的自动化程度将进一步提高,开发者可以将更多精力集中在业务逻辑的开发上,为项目带来更大的价值。
相关文章:
Spring Boot 项目中 Maven 剔除无用 Jar 引用的最佳实践
目录 引言Maven 依赖管理的基础概念 2.1 什么是 Maven 依赖2.2 Maven 的依赖传递机制 无用依赖的常见问题与影响剔除无用 Jar 引用的常见方法 4.1 识别无用依赖4.2 使用 Maven 的 dependency:analyze 插件4.3 配置 scope 以优化依赖范围4.4 使用 exclude 排除传递依赖4.5 分析…...
useWhyDidYouUpdate详解
目录 API Params demo演示 源码 useWhyDidYouUpdate是ahooks库中的一个hook函数,用于帮助开发者排查是哪个属性改变导致了组件的 rerender。 API type IProps Record<string, any>;useWhyDidYouUpdate(componentName: string, props: IProps): void; …...
c++入门——c++输入cin和输出cout的简单使用
c输入cin、输出cout 1 cin2 cout3 cin和cout说明 c在c语言的输入、输出函数的基础上进行了封装。 1 cin c可以理解为控制台,in可以理解为输入。 参考代码: void f(){int a;float b;double c;char d;cin>>a>>b>>c>>d;//这里和…...
Spring Cloud LoadBalancer (负载均衡)
目录 什么是负载均衡 服务端负载均衡 客户端负载均衡 Spring Cloud LoadBalancer快速上手 启动多个product-service实例 测试负载均衡 负载均衡策略 自定义负载均衡策略 什么是负载均衡 负载均衡(Load Balance,简称 LB) , 是高并发, 高可用系统必不可少的关…...
微服务-1 认识微服务
目录 1 认识微服务 1.1 单体架构 1.2 微服务 1.3 SpringCloud 2 服务拆分原则 2.1 什么时候拆 2.2 怎么拆 2.3 服务调用 3. 服务注册与发现 3.1 注册中心原理 3.2 Nacos注册中心 3.3 服务注册 3.3.1 添加依赖 3.3.2 配置Nacos 3.3.3 启动服务实例 …...
基于51单片机的交通灯带拐弯proteus仿真
地址: https://pan.baidu.com/s/1cgqRHMHp9VJet4vs5LiG5A 提取码:1234 仿真图: 芯片/模块的特点: AT89C52/AT89C51简介: AT89C52/AT89C51是一款经典的8位单片机,是意法半导体(STMicroelectro…...
1229java面经
1,Java中synchronized关键字是否是可重入的? 可重入的定义 可重入是指当一个线程已经获取了某个对象的锁,在该锁没有释放的情况下,如果这个线程再次请求获取这个对象的锁,是可以成功获取的,而不会出现自己把自己锁死的情况。简单…...
MySQL中查看表结构
1. 使用 DESCRIBE 或 DESC 命令 DESCRIBE(或其简写 DESC)是最简单和最直接的方法,可以显示表的列信息。 语法: DESCRIBE table_name; -- 或者 DESC table_name;示例: 假设有一个名为 employees 的表,可以…...
python利用selenium实现大麦网抢票
大麦网(damai.cn)是中国领先的现场娱乐票务平台,涵盖演唱会、音乐会、话剧、歌剧、体育赛事等多种门票销售。由于其平台上经常会有热门演出,抢票成为许多用户关注的焦点。然而,由于票务资源的有限性,以及大…...
FME教程:一键批量调换图斑X、Y坐标,解决因为坐标弄反了,导致GIS弹窗提示“范围不一致”警告问题
目录 一、实现效果 二、实现过程 1.读取数据 2.提取坐标 3.调换图斑的X、Y坐标 4.输出成果 5.模板的使用 三、总结 在工作中有时候会出现因为失误导致图斑的X、Y坐标弄反,在GIS中打开是会提示“范围不一致”警告的弹窗警告,如果重做工作量非常大…...
OpenCV-Python实战(4)——图像处理基础知识
一、坐标 在 OpenCV 中图像左上角坐标为(0,0),竖直向下为 Y(height) ;水平向右为 X(width)。 二、生成图像 2.1 灰度图像 img np.zeros((h,w), dtype np.uint8) i…...
音视频入门基础:MPEG2-PS专题(1)——MPEG2-PS官方文档下载
一、引言 MPEG2-PS(又称PS,Program Stream,程序流,节目流)是一种多路复用数字音频、视频等的封装容器。MPEG2-PS将一个或多个分组但有共同的时间基准的基本数据流 (PES)合并成一个整体流。它是…...
Qt自定义步骤引导按钮
1. 步骤引导按钮 实际在开发项目过程中,由一些流程比较繁琐,为了给客户更好的交互体验,往往需要使用step1->step2这种引导对话框或者引导按钮来引导用户一步步进行设置;话不多说,先上效果 2. 实现原理 实现起来…...
贝叶斯神经网络(Bayesian Neural Network)
最近在研究贝叶斯神经网络,一些概念一直搞不清楚,这里整理一下相关内容,方便以后查阅。 贝叶斯神经网络(Bayesian Neural Network) 贝叶斯神经网络(Bayesian Neural Network)1. BNN 的核心思想2. BNN 的优化目标3. BNN 的结构与特点4. BNN 的训练过程5. BNN 的优缺点6. …...
Direct Preference Optimization: Your Language Model is Secretly a Reward Model
DPO直接偏好优化:你的语言模型实际上是一个奖励模型 前言知识储备 什么是用户偏好数据目的:用于指导模型行为,使其输出更符合特定用户或者用户群体期望和喜好的信息。 用户偏好数据通常反映了用户对特定内容、风格、观点或者互动方式的倾向。 用户偏好数据的收集通常涉及直…...
如何通过 Kafka 将数据导入 Elasticsearch
作者:来自 Elastic Andre Luiz 将 Apache Kafka 与 Elasticsearch 集成的分步指南,以便使用 Python、Docker Compose 和 Kafka Connect 实现高效的数据提取、索引和可视化。 在本文中,我们将展示如何将 Apache Kafka 与 Elasticsearch 集成以…...
嵌入式系统 第十二讲 块设备和驱动程序设计
• 块设备是Linux三大设备之一(另外两种是字符设备,网络设备),块 设备也是通过/dev下的文件系统节点访问。 • 块设备的数据存储单位是块,块的大小通常为512B至32KB不等。 • 块设备每次能传输一个或多个块,…...
攻防世界web第六题upload
这是题目,可以看出是个上传文件的题目,考虑文件上传漏洞,先随便上传一个文件试试,要求上传的是图片。 可以看到上传成功。 考虑用一句话木马解决,构造文件并修改后缀为jpg,然后上传。 <?php eval($_POST[attack])…...
人工智能-Python网络编程-HTTP
用Python创建自己的HTTP服务器 方案一 HTTP-Python官方 python -m http.server 80 方案二 HTTP-概念版 import socketIPV4_ADDR 192.168.124.7 IPV4_PORT 8888# TCP 服务端程序必须绑定端口号,否则客户端找不到这个 TCP 服务端程序 class ServerSocket(obje…...
探索仓颉编程语言:功能、实战与展望
目录 引言 一.使用体验 二.功能剖析 1.丰富的数据类型与控制结构 2.强大的编程范式支持 3.标准库与模块系统 4.并发编程能力 三.实战案例 1.项目背景与目标 2.具体实现步骤 (1).导入必要的模块 (2).发送 HTTP 请求获取网页内容 (3).解析 HTML 页面提取文章信息 (…...
linux之kylin系统nginx的安装
一、nginx的作用 1.可做高性能的web服务器 直接处理静态资源(HTML/CSS/图片等),响应速度远超传统服务器类似apache支持高并发连接 2.反向代理服务器 隐藏后端服务器IP地址,提高安全性 3.负载均衡服务器 支持多种策略分发流量…...
Admin.Net中的消息通信SignalR解释
定义集线器接口 IOnlineUserHub public interface IOnlineUserHub {/// 在线用户列表Task OnlineUserList(OnlineUserList context);/// 强制下线Task ForceOffline(object context);/// 发布站内消息Task PublicNotice(SysNotice context);/// 接收消息Task ReceiveMessage(…...
服务器硬防的应用场景都有哪些?
服务器硬防是指一种通过硬件设备层面的安全措施来防御服务器系统受到网络攻击的方式,避免服务器受到各种恶意攻击和网络威胁,那么,服务器硬防通常都会应用在哪些场景当中呢? 硬防服务器中一般会配备入侵检测系统和预防系统&#x…...
实现弹窗随键盘上移居中
实现弹窗随键盘上移的核心思路 在Android中,可以通过监听键盘的显示和隐藏事件,动态调整弹窗的位置。关键点在于获取键盘高度,并计算剩余屏幕空间以重新定位弹窗。 // 在Activity或Fragment中设置键盘监听 val rootView findViewById<V…...
鸿蒙DevEco Studio HarmonyOS 5跑酷小游戏实现指南
1. 项目概述 本跑酷小游戏基于鸿蒙HarmonyOS 5开发,使用DevEco Studio作为开发工具,采用Java语言实现,包含角色控制、障碍物生成和分数计算系统。 2. 项目结构 /src/main/java/com/example/runner/├── MainAbilitySlice.java // 主界…...
消息队列系统设计与实践全解析
文章目录 🚀 消息队列系统设计与实践全解析🔍 一、消息队列选型1.1 业务场景匹配矩阵1.2 吞吐量/延迟/可靠性权衡💡 权衡决策框架 1.3 运维复杂度评估🔧 运维成本降低策略 🏗️ 二、典型架构设计2.1 分布式事务最终一致…...
Java详解LeetCode 热题 100(26):LeetCode 142. 环形链表 II(Linked List Cycle II)详解
文章目录 1. 题目描述1.1 链表节点定义 2. 理解题目2.1 问题可视化2.2 核心挑战 3. 解法一:HashSet 标记访问法3.1 算法思路3.2 Java代码实现3.3 详细执行过程演示3.4 执行结果示例3.5 复杂度分析3.6 优缺点分析 4. 解法二:Floyd 快慢指针法(…...
数据库正常,但后端收不到数据原因及解决
从代码和日志来看,后端SQL查询确实返回了数据,但最终user对象却为null。这表明查询结果没有正确映射到User对象上。 在前后端分离,并且ai辅助开发的时候,很容易出现前后端变量名不一致情况,还不报错,只是单…...
跨平台商品数据接口的标准化与规范化发展路径:淘宝京东拼多多的最新实践
在电商行业蓬勃发展的当下,多平台运营已成为众多商家的必然选择。然而,不同电商平台在商品数据接口方面存在差异,导致商家在跨平台运营时面临诸多挑战,如数据对接困难、运营效率低下、用户体验不一致等。跨平台商品数据接口的标准…...
32位寻址与64位寻址
32位寻址与64位寻址 32位寻址是什么? 32位寻址是指计算机的CPU、内存或总线系统使用32位二进制数来标识和访问内存中的存储单元(地址),其核心含义与能力如下: 1. 核心定义 地址位宽:CPU或内存控制器用32位…...
