Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

2025-07-17 19:50

本文主要是介绍Spring Boot Maven 插件如何构建可执行 JAR 的核心配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理...

前言

Java 生态中,Spring Boot 以其“约定优于配置”的理念和开箱即用的特性,成为现代应用开发的首选框架。而 spring-boot-maven-plugin 作为 Spring Boot 的核心插件,承担着将应用打包为可执行 JAR/WAR 的关键角色。

一、插件的核心功能与目标

1.1 插件的定位

spring-boot-maven-plugin 是 Spring Boot 提供的 Maven 插件,其核心目标是:

  • 可执行包生成:将应用及其依赖打包为独立的 JAR/WAR 文件,支持通过 java -jar 直接运行。
  • 生命周期管理:在集成测试阶段启动/停止应用,支持自动化测试。
  • 构建信息管理:生成 build-info.properties 文件,供 Actuator 等组件使用。
  • 热部署支持:与 Spring Boot DevTools 集成,实现代码修改后的自动重启。

1.2 插件的 Goals(目标)

该插件定义了 5 个核心目标(Goal),分别对应不同的构建阶段:

Goal作用
repackagemvn package 后重新打包,生成可执行的 JAR/WAR(保留原始包为 .origin 文件)。
run通过 mvn spring-boot:run 直接运行应用,无需显式打包。
start在集成测试阶段启动应用(非阻塞),常用于测试前的初始化。
stop在集成测试完成后停止由 start 启动的应用。
build-info生成 build-info.properties 文件,记录项目版本、构建时间等元信息。

1.3 插件定位

spring-boot-maven-plugin 是 Spring Boot 提供的官方 Maven 插件,其核心目标是将 Spring Boot 应用程序打包为可独立运行的 JAR 或 WAR 文件。与传统 Maven 打包方式不同,该插件生成的可执行文件内置了嵌入式服务器(如 Tomcat、Jetty),无需依赖外部容器即可运行,极大简化了部署流程。

1.4 核心功能

  • 可执行文件打包:将应用及其所有依赖打包为单一 JAR/WAR,支持 java -jar 直接运行。
  • 生命周期管理:支持集成测试阶段的应用启动与停止。
  • php发者工具集成:结合 Spring Boot DevTools 实现热部署。
  • 构建信息生成:生成 build-info.properties 文件,记录项目元数据。

二、核心配置详解

2.1 <mainClass>:指定入口类

<configuration>
    <mainClass>com.example.Application</mainClass>
</configuration>
  • 作用:定义应用的主类(包含 @SpringBootApplication 注解的类)。
  • 原理:插件会在生成的 JAR 包的 MANIFEST.MF 中写入以下内容:
    Main-Class: org.springframework.boot.loader.JarLauncher
    Start-Class: com.example.Application
  • 注意事项
    • 若未显式配置,插件会自动扫描项目中带有 @SpringBootApplication 的类。
    • 对于多模块项目,需确保主类路径正确,避免冲突。

2.2 <skip>:跳过插件执行

<configuration>
    <skip>true</skip>
</configuration>
  • 作用:控制是否跳过 repackage 等操作。
  • 适用场景
    • 快速构建时仅生成普通 JAR(如 mvn package 后直接部署)。
    • 调试阶段避免重复打包。
  • 默认值false

2.3 <includeSystemScope>:包含系统依赖

<configuration>
    <includeSystemScope>true</includeSystemScope>
</configuration>
  • 作用:是否将 system 作用域的依赖(通过 <systemPath> 引入的本地 JAR)包含到最终包中。
  • 风险提示
    • 系统依赖依赖于本地路径,可能导致构建不可移植。
    • 建议:优先使用 filemaven 仓库管理依赖。

2.4 <layout>:定义打包格式

<configuration>
    <layout>JAR</layout>
</configuration>
  • 支持的值

    描述
    JAR可执行 JAR,使用 JarLauncher 启动(默认值)。
    WAR可执行 WAR,使用 WarLauncher 启动,需配置 servlet 容器。
    ZIP类似 JAR 的 ZIP 包,使用 PropertiesLauncChina编程her 启动。
    NONE仅打包依赖,不包含 Spring Boot 启动器(不可执行)。
    MODULE打包依赖库(排除 provided 作用域),不包含启动器。
  • 选择策略

    • Web 应用优先使用 WAR
    • 微服务或独立应用使用 JAR
    • 高度定制化场景选择 NONEMODULE

2.5 <executions>:绑定构建生命周期

(1) repackage 目标

<executions>
    <execution>
        <id>repackage</id>
        <goals>
            <goal>repackage</goal>
        </goals>
    </execution>
</executions>
  • 作用:将 repackage 目标绑定到 package 阶段。
  • 结果:执行 mvn package 后,插件会自动生成可执行包,并覆盖原始包(保留为 .origin 文件)。
  • 生成结构
    your-app.jar
    ├── META-INF/
    │   └── MANIFEST.MF
    ├── org/springframework/boot/loader/  # 启动类
    └── BOOT-INF/
        ├── classes/  # 项目编译后的类文件
        └── lib/      # 所有依赖的 .jar 文件
  • 执行命令
    mvn clean package
    java -jar target/your-app.jar

(2) run 目标

mvn spring-boot:run
  • 作用:直接运行 Spring Boot 应用,无需打包。
  • 适用场景:快速调试或开发阶段。

(3) startstop 目标

<execution>
    <id>start</id>
    <goals>
        <goal>start</goal>
    </goals>
</execution>
<execution>
    <id>stop</id>
    <goals>
        <goal>stop</goal>
    </goals>
</execution>
  • 作用:在集成测试阶段启动/停止应用。
  • 典型流程
    mvn integration-test  # 启动应用
    mvn verify            # 停止应用

(4) build-info 目标

<execution>
    <goals>
        <goal>build-info</goal>
    </goals>
</execution>
  • 作用:生成 build-info.properties 文件,记录项目版本、构建时间等元数据。
  • 文件内容示例
    build.artifact=your-app
    build.name=your-app
    build.version=1.0.0
    build.time=2025-07-13T18:14:03Z

三、高级配置与最佳实践

3.1 多环境配置

通过 php<profiles> 动态切换配置文件:

<profiles>
    <profile>
        <id>dev</id>
        <properties>
            <env>dev</env>
        </properties>
    </profile>
    <profile>
        <id>prod</id>
        <properties>
            <env>prod</env>
        </properties>
    </profile>
</profiles>

结合资源过滤(resources 配置)实现不同环境的配置分离。

3.2 与 Spring Boot DevTools 集成

启用热部署(HotSwap):

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <optional>true</optional>
    </dependency>
</dependencies>
  • 效果:代码修改后,应用会自动重启(无需手动执行 mvn package)。

3.3 自定义构建信息

通过 build-info 目标生成元数据:

<execution>
    <id>generate-build-info</id>
    <goals>
        <goal>build-info</goal>
    </goals>
    <phase>process-resources</phase>
</execution>

生成的 build-info.properties 示例:

build.artifact=example-app
build.name=example-app
build.version=1.0.0
build.time=2025-07-13T22:00:09Z

四、典型配置示例

4.1 基础配置

<plugin>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-maven-plugin</artifactId>
    <version>${spring-boot.version}</version>
    <configuration>
        <mainClass>com.example.Application</mainClass>
        <skip>false</skip>
        <includeSystemScope>false</includeSystemScope>
        <layout>JAR</layout>
    </configuration>
    <executions>
        <execution>
            <id>repackage</id>
            <goals>
                <goal>repackage</goal>
            </goals>
        </execution>
    </executions>
</plugin>

4.2 高级配置(集成 DevTools 与多环境)

<profChina编程iles>
    <profile>
        <id>dev</id>
        <properties>
            <env>dev</env>
        </properties>
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                    <configuration>
                        <mainClass>com.example.Application</mainClphpass>
                        <layout>JAR</layout>
                    </configuration>
                    <executions>
                        <execution>
                            <id>repackage</id>
                            <goals>
                                <goal>repackage</goal>
                            </goals>
                        </execution>
                    </executions>
                </plugin>
            </plugins>
        </build>
    </profile>
</profiles>

五、常见问题与解决方案

5.1 启动类未正确识别

  • 现象:运行 java -jar app.jar 报错 No main manifest attribute
  • 原因:未正确配置 <mainClass> 或自动扫描失败。
  • 解决方案
    1. 显式配置 <mainClass>
    2. 确保主类路径正确(src/main/java/com/example/Application.java)。
    3. 检查 @SpringBootApplication 注解是否缺失。

5.2 依赖冲突

  • 现象:运行时报错 java.lang.NoSuchMethodError
  • 原因:依赖版本不一致或存在多个同名 JAR。
  • 解决方案
    • 使用 mvn dependency:tree 分析依赖树。
    • 通过 <exclusions> 排除冲突依赖。
    • 升级 Spring Boot 版本以获取最新依赖管理。

5.3 打包后体积过大

  • 现象:生成的 JAR 文件体积异常庞大。
  • 原因:包含大量未使用的依赖或重复资源。
  • 解决方案
    • 使用 spring-boot-maven-pluginexclude 配置过滤无用依赖。
    • 启用 spring-boot:repackageskip 模式,仅打包必要依赖。

六、总结

spring-boot-maven-plugin 是 Spring Boot 项目构建的基石,其配置直接影响应用的打包效率、运行性能及维护成本。通过合理配置 <mainClass><layout><executions> 等参数,开发者可以灵活控制构建流程,适配不同场景需求。同时,结合 DevTools、多环境配置等高级特性,能够显著提升开发效率与部署灵活性。

到此这篇关于Spring Boot Maven 插件如何构建可执行 JAR 的核心配置的文章就介绍到这了,更多相关Spring Boot Maven可执行jar内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程China编程(www.chinasem.cn)!

这篇关于Spring Boot Maven 插件如何构建可执行 JAR 的核心配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1155416

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三