spring boot项目打包遇到无法找到主类

pom中

  <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <version>${spring-boot.version}</version>
                <configuration>
                    <mainClass>org.example.dockertest.DockertestApplication</mainClass>
					  <skip>true</skip>删除
                </configuration>
                <executions>
                    <execution>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>

删除skip行
manifest.mf中就会有mainclass属性就可以运行了

在使用 Maven 构建 Spring Boot 项目时,指定的方式通常依赖于 `spring-boot-maven-plugin` 插件的配置。该插件提供了对 Spring Boot 项目打包和运行的支持,同时允许开发者显式声明,以确保生成的 JAR 文件能够正确识别程序入口点。 在 `pom.xml` 文件中,需要配置 `spring-boot-maven-plugin` 插件,并通过 `<mainClass>` 元素指定的全限定名。例如,若为 `com.ruoyi.RuoYiApplication`,则配置如下: ```xml <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <version>2.5.6</version> <configuration> <mainClass>com.ruoyi.RuoYiApplication</mainClass> </configuration> <executions> <execution> <goals> <goal>repackage</goal> </goals> </execution> </executions> </plugin> </plugins> </build> ``` 上述配置确保在执行 `mvn clean package` 命令后,生成的 JAR 文件中包含正确的信息,从而允许通过 `java -jar` 命令启动应用时正确加载 [^2]。 此外,Spring Boot Maven 插件默认会尝试自动检测,并在 `MANIFEST.MF` 文件中写入相应的 `Main-Class` 条目。然而,在某些情况下,如项目结构复杂或多模块项目中,自动检测可能不准确,因此显式配置仍然是推荐做法 [^3]。 如果使用 `maven-jar-plugin` 而非 `spring-boot-maven-plugin`,也可以通过 `<mainClass>` 配置,但这种方式不适用于 Spring Boot 项目的完整打包需求,因为其不包含依赖库 [^2]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值