当前位置: 首页 > web >正文

Maven 项目构建时编译错误问题排查与解决

1. 问题描述

Maven 项目执行命令 mvn clean package 时出现编译错误,如下图所示
mvn 构建错误日志

2. 问题分析

由于是源码编译错误,于是通过查看项目 pom.xml 文件,得到项目源码使用的 Java 版本为 21

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><properties><maven.compiler.source>21</maven.compiler.source><maven.compiler.target>21</maven.compiler.target></properties><build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><configuration><!-- 源码的 Java 版本为 21 --><source>${maven.compiler.source}</source><!-- 最终源码编译为的 Java 版本为 21 --><target>${maven.compiler.target}</target></configuration></plugin></plugins></build>
</project>

再执行命令 mvn -v ,可知当前 mvn 命令依赖的 Java 环境是 Java 17,如下图所示,而项目源码需要编译为 Java 21,这相当于要使用 Java 17 编译生成 Java 21 的字节码,导致构建失败。
mvn 版本信息

Maven 本身也是一个 Java 应用,也就是说它本身的运行也是要基于 JVM 的,mvn -v 命令的输出信息中的 Java 版本就是其运行时依赖的 Java 环境;

Maven 的编译器插件 maven-compiler-plugin 其实并不知道如何编译 Java 源码,它实际是调用了 JDK 中的 javac 工具完成编译的,而这里的 javac 工具就是来源于 Maven 运行时依赖的 Java 环境;

javac 工具考虑了向后兼容性,即允许高版本的 javac 将源码编译为与其版本相同或者比其版本低的字节码,但是无法生成比起自身版本更高的字节码;

3. 问题解决

思路方向:升级 Maven 运行时的 Java 版本(即升级对应 javac 工具的版本)。

我们知道,使用 Maven 前,需要提前设置 Java 环境,设置好对应的 JAVA_HOME 环境变量,所以我们可以直接调整系统的环境变量 JAVA_HOME,让其指向 Java 21,再进行项目构建。但是这样调整会影响系统的其它 Maven 项目,其它 Maven 项目不一定都是使用 Java 21 的,所以采用下面的解决方案:

# 先在当前命令会话临时设置 JAVA_HOME 环境变量(如果是 Windows 系统,语法稍有不同)
JAVA_HOME=/path/to/java/21
# 再执行命令构建
mvn clean package

mvn 构建成功日志

注:可以通过查看 $MAVEN_HOME/bin/mvn 运行脚本的源码知道设置 JAVA_HOME 环境变量起作用的原因。

4. 问题记录

个人在解决问题过程中,发现在当前命令会话临时设置 JAVA_HOME 环境变量一直无法生效,后面经过一番艰辛探索,发现是个人系统存在 mavenrc 的相关文件导致的,该文件是 ~/.mavenrc,其文件内容为:

export JAVA_HOME=/usr/local/java/jdk-17.0.1

$MAVEN_HOME/bin/mvn 运行脚本会加载该文件,导致当前命令会话临时设置的 JAVA_HOME 环境变量被覆盖了。
加载 mavenrc 文件脚本源码
最后,考虑到 ~/.mavenrc 这种文件属于特定平台的配置,而不是 Maven 的标准配置,于是直接删除 ~/.mavenrc 文件,以便顺利解决问题。

http://www.xdnf.cn/news/5639.html

相关文章:

  • Spring Boot整合Kafka实战指南:从环境搭建到消息处理全解析
  • 【MCP】魔搭社区MCP服务(高德地图、everything文件搜索)
  • Ai网站流式渲染总结
  • c语言第一个小游戏:贪吃蛇小游戏03
  • #在 CentOS 7 中手动编译安装软件操作及原理
  • 03.Golang 切片(slice)源码分析(二、append实现)
  • 视频监控汇聚平台EasyCVR安防视频监控小知识:视频监控系统与监视器安装
  • 【Redis实战篇】分布式锁-Redisson
  • 最新AI产品库哪个平台好?最新AI工具网站平台推荐
  • C++中的std::allocator
  • 神经生物学+图论双buff,揭示大脑语言系统的拓扑结构
  • Android学习总结之线程池篇
  • 脑机接口重点产品发展路径分析:以四川省脑机接口及人机交互产业攻坚突破行动计划(2025-2030年)为例
  • Matlab 短时交通流预测AR模型
  • 【C#】ToArray的使用
  • 将本地文件上传到云服务器上
  • Matlab 模糊控制节水洗衣机模型
  • Next.js 知识框架总结
  • 212. 单词搜索 II【 力扣(LeetCode) 】
  • windows下docker 运行 ros2humble arm64
  • day 23
  • VIC-2D 7.0 为平面样件机械试验提供全视野位移及应变数据软件
  • MySQL是如何加行级锁的
  • Java大师成长计划之第19天:性能调优与GC原理
  • C# 中 static的使用
  • 计算机网络核心技术解析:从基础架构到应用实践
  • 2025年阿里云大数据ACP高级工程师认证模拟试题(附答案解析)
  • 基于Vue3.0的高德地图api教程004:自定义绘制点的颜色/修改绘制点/删除绘制点
  • RCE联系
  • 什么是ERP?ERP有哪些功能?小微企业ERP系统源码,SpringBoot+Vue+ElementUI+UniAPP