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 只服务于有启动类的业务模块,就能彻底解决问题

相关推荐
无限的鲜花6 小时前
反射(原创推荐)
java·开发语言
IT二叔7 小时前
Java项目部署-03-teamcity-cicd-docker镜像流水线方式部署
java·ci/cd·持续部署
一路向北he7 小时前
字节钢铁军团--“提供情境,而非控制”
java·开发语言·前端
超级数据查看器7 小时前
超级数据查看器 v10.0 发布
java·大数据·数据库·sqlite·安卓
折哥的程序人生 · 物流技术专研9 小时前
《Java 100 天进阶之路》第50篇:阻塞队列与并发容器(2026版)
java·面试题·java进阶·blockingqueue·并发容器·集合源码·java100天进阶
ai_coder_ai9 小时前
编写自动化脚本,在自己后端服务中使用Open Api进行设备相关操作
java·运维·自动化
硕风和炜9 小时前
【LeetCode: 2492. 两个城市间路径的最小分数 + DFS】
java·算法·leetcode·深度优先·dfs·bfs·并查集
格子软件10 小时前
2026年GEO贴牌代理:分布式多级分账状态机源码深度解构
java·vue.js·分布式·vue·geo
我是一颗柠檬10 小时前
【Java项目技术亮点】加权轮询负载均衡算法
java·算法·负载均衡
灯厂码农10 小时前
C语言动态内存分配完全指南(malloc、calloc、realloc、free)
java·c语言·算法