Spring Boot 生成 jar/war包的布局应用

在 Spring Boot 中,"布局应用"(Application Layout)指的是打包生成的可执行 jar 或 war 文件中的内容组织结构。Spring Boot 使用一种特殊的布局来确保打包的应用可以通过 java -jar 命令直接运行,同时内嵌 Servlet 容器(如 Tomcat、Jetty 或 Undertow)也被包含在内,使得应用可以作为一个独立的微服务运行,无需外部的 Servlet 容器。

标准的 Java 应用布局:

在传统的 Java 应用中,一个 jar 文件通常包含以下结构:

js 复制代码
my-application.jar
│
├── META-INF
│   └── MANIFEST.MF
├── com
│   └── example
│       └── MyApplication.class
└── lib
    ├── dependency1.jar
    ├── dependency2.jar
    └── ...
  • META-INF/MANIFEST.MF 文件包含元数据,如主类(Main-Class)。
  • 应用的类文件(如 MyApplication.class)直接包含在 jar 文件的根目录下。
  • 依赖的库(如 dependency1.jardependency2.jar)通常位于 lib 目录下,或者完全分离,需要在运行时通过类路径(classpath)指定。

Spring Boot 的可执行 jar 布局:

Spring Boot 改变了这种布局来支持自包含的、可执行的 jar 文件,这种文件被称为"胖 jar"(Fat Jar)或"超级 jar"(Uber Jar),其结构如下:

vbnet 复制代码
vbnetCopy code
my-spring-boot-application.jar
│
├── META-INF
│   ├── MANIFEST.MF
│   └── ...
├── org
│   └── springframework
│       └── boot
│           └── loader
│               ├── JarLauncher.class
│               ├── WarLauncher.class
│               ├── ...
│
├── BOOT-INF
│   ├── classes
│   │   └── com
│   │       └── example
│   │           └── MyApplication.class
│   │
│   └── lib
│       ├── spring-boot-starter-web-2.3.0.RELEASE.jar
│       ├── my-other-dependency-1.0.0.jar
│       └── ...
│
└── application.properties
  • META-INF/MANIFEST.MF 包含 Spring Boot 特有的元数据,指定了使用 Spring Boot 类加载器框架的启动类(如 JarLauncher)。
  • 应用的类文件被放在 BOOT-INF/classes 目录下。
  • 应用的所有依赖库被放在 BOOT-INF/lib 目录下。
  • Spring Boot 的类加载器框架相关的类位于 org/springframework/boot/loader 下,这些类负责正确地加载 BOOT-INF 下的类和库。

为什么需要这种特殊布局:

这种特殊的布局允许 Spring Boot 应用将自己的类和第三方库隔离开来,避免了类路径冲突的问题,并确保了应用可以作为一个独立的单元被运行。这种布局使得部署和分发 Spring Boot 应用变得非常简单,因为所有需要的东西都被封装在一个文件内,无需额外的配置或外部依赖。

相关推荐
小王不爱笑1322 小时前
@PropertySource&@ImportResource&@Bean
spring boot
Wyy_9527*2 小时前
行为型设计模式——状态模式
java·spring boot·后端
编程彩机2 小时前
互联网大厂Java面试:从分布式事务到微服务架构场景应用
spring boot·分布式事务·微服务架构·java面试·电商场景
梅梅绵绵冰3 小时前
springboot初步2
java·spring boot·后端
VX:Fegn08954 小时前
计算机毕业设计|基于springboot + vue教务管理系统(源码+数据库+文档)
vue.js·spring boot·课程设计
小北方城市网4 小时前
Spring Cloud Gateway 自定义过滤器深度实战:业务埋点、参数校验与响应改写
运维·jvm·数据库·spring boot·后端·mysql
梅梅绵绵冰4 小时前
springboot初步1
java·前端·spring boot
jason.zeng@15022074 小时前
POM构造Spring boot多模块项目
java·spring boot·后端
indexsunny4 小时前
互联网大厂Java面试实录:Spring Boot微服务在电商场景中的应用与挑战
java·spring boot·redis·mysql·security·microservices·interview
猿与禅5 小时前
Spring Boot 3.x 集成 Caffeine 缓存框架官方指南
spring boot·后端·缓存·caffeine