Maven 聚合工程打包报错:Unable to find main class 快速解决

Maven 聚合工程打包时,Unable to find main class 是高频报错,尤其在包含工具类模块的项目中,根源很简单,解决也只要一步到位。

一、报错原因

聚合工程里,工具类模块不需要 main 启动类 ,但父工程的 pom.xml 中配置了 spring-boot-maven-plugin 插件。

这个插件的作用是打包可执行的 Spring Boot jar 包,打包时会强制扫描 main 启动类。当插件透传给无启动类的工具模块时,就会直接抛出 "找不到主类" 的错误。

二、解决方案

核心思路:spring-boot-maven-plugin 只配置在有启动类的业务模块中,父工程移除该插件

  1. 修改父工程 pom.xml 直接删除或注释掉 spring-boot-maven-plugin 相关配置:

    xml

    复制代码
    <!-- 父工程pom.xml 移除以下插件配置 -->
    <!--
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <configuration>
                <excludes>
                    <exclude>
                        <groupId>org.projectlombok</groupId>
                        <artifactId>lombok</artifactId>
                    </exclude>
                </excludes>
            </configuration>
        </plugin>
    </plugins>
    -->
  2. 配置业务模块 pom.xml在有 main 启动类的业务模块中,单独添加该插件:

    xml

    复制代码
    <!-- 业务模块(如service-user)的pom.xml -->
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <!-- 可选:指定启动类全路径 -->
                    <mainClass>com.example.user.UserApplication</mainClass>
                </configuration>
            </plugin>
        </plugins>
    </build>

三、验证打包

执行 Maven 打包命令:

bash

运行

复制代码
mvn clean package -DskipTests

无报错即表示配置生效,工具类模块打包为普通 jar,业务模块打包为可执行 Spring Boot jar。

总结

这个报错的核心是插件配置范围不对 ,只需让 spring-boot-maven-plugin 只服务于有启动类的业务模块,就能彻底解决问题

相关推荐
lee_curry3 小时前
第四章 jvm中的垃圾回收器
java·jvm·垃圾收集器
九转成圣4 小时前
Java 性能优化实战:如何将海量扁平数据高效转化为类目字典树?
java·开发语言·json
直奔標竿5 小时前
Java开发者AI转型第二十七课!Spring AI 个人知识库实战(六)——全栈闭环收官,解锁前端流式渲染终极技巧
java·开发语言·前端·人工智能·后端·spring
金銀銅鐵5 小时前
[java] 编译之后的记录类(Record Classes)长什么样子(上)
java·jvm·后端
野生技术架构师7 小时前
金三银四面试总结篇,汇总 Java 面试突击班后的面试小册
java·面试·职场和发展
小袁拒绝摆烂7 小时前
多表关联大平层转JSON树形结构
java·json
ja哇8 小时前
大厂面试高频八股
java·面试·职场和发展
yoyo_zzm9 小时前
Laravel6.x新特性全解析
java·spring boot·后端
Nick_zcy9 小时前
小说在线阅读网站和小说管理系统 · 功能全解析
java·后端·python·springboot·ruoyi