构建系统
强烈建议您选择一个支持 依赖管理 并且可以消费发布到“Maven Central”存储库的工件的构建系统。我们建议您选择 Maven 或 Gradle。Spring Boot 可以与其他构建系统(例如 Ant)一起使用,但它们的支持度并不高。
依赖管理
每个 Spring Boot 版本都提供了一份经过精心挑选的依赖项列表,这些依赖项是它支持的。在实际应用中,您不需要在构建配置中为这些依赖项提供版本,因为 Spring Boot 会为您管理这些版本。当您升级 Spring Boot 本身时,这些依赖项也会以一致的方式升级。
您仍然可以指定版本并覆盖 Spring Boot 的建议,如果您需要这样做。 |
这份精心挑选的列表包含了您可以与 Spring Boot 一起使用的所有 Spring 模块,以及经过优化的第三方库列表。该列表以标准的物料清单 (spring-boot-dependencies
) 的形式提供,可与 Maven 和 Gradle 一起使用。
每个 Spring Boot 版本都与 Spring Framework 的基本版本相关联。我们 **强烈** 建议您不要指定它的版本。 |
Ant
可以使用 Apache Ant+Ivy 构建 Spring Boot 项目。spring-boot-antlib
“AntLib” 模块也可用于帮助 Ant 创建可执行的 jar 文件。
要声明依赖项,典型的 ivy.xml
文件类似于以下示例
<ivy-module version="2.0">
<info organisation="org.springframework.boot" module="spring-boot-sample-ant" />
<configurations>
<conf name="compile" description="everything needed to compile this module" />
<conf name="runtime" extends="compile" description="everything needed to run this module" />
</configurations>
<dependencies>
<dependency org="org.springframework.boot" name="spring-boot-starter"
rev="${spring-boot.version}" conf="compile" />
</dependencies>
</ivy-module>
典型的 build.xml
文件类似于以下示例
<project
xmlns:ivy="antlib:org.apache.ivy.ant"
xmlns:spring-boot="antlib:org.springframework.boot.ant"
name="myapp" default="build">
<property name="spring-boot.version" value="3.3.0" />
<target name="resolve" description="--> retrieve dependencies with ivy">
<ivy:retrieve pattern="lib/[conf]/[artifact]-[type]-[revision].[ext]" />
</target>
<target name="classpaths" depends="resolve">
<path id="compile.classpath">
<fileset dir="lib/compile" includes="*.jar" />
</path>
</target>
<target name="init" depends="classpaths">
<mkdir dir="build/classes" />
</target>
<target name="compile" depends="init" description="compile">
<javac srcdir="src/main/java" destdir="build/classes" classpathref="compile.classpath" />
</target>
<target name="build" depends="compile">
<spring-boot:exejar destfile="build/myapp.jar" classes="build/classes">
<spring-boot:lib>
<fileset dir="lib/runtime" />
</spring-boot:lib>
</spring-boot:exejar>
</target>
</project>
如果您不想使用 spring-boot-antlib 模块,请参阅在不使用 spring-boot-antlib 的情况下从 Ant 构建可执行存档 “操作指南”。
|
启动器
启动器是一组方便的依赖项描述符,您可以将其包含在您的应用程序中。您将获得一站式服务,提供您需要的所有 Spring 和相关技术,而无需在示例代码中搜索并复制粘贴大量依赖项描述符。例如,如果您想开始使用 Spring 和 JPA 进行数据库访问,请在您的项目中包含 spring-boot-starter-data-jpa
依赖项。
启动器包含了许多您需要快速启动并运行项目以及一致、受支持的已管理传递依赖项集的依赖项。
以下应用程序启动器由 Spring Boot 在org.springframework.boot
组下提供
名称 | 描述 |
---|---|
核心启动器,包括自动配置支持、日志记录和 YAML |
|
使用 Apache ActiveMQ 进行 JMS 消息传递的启动器 |
|
使用 Spring AMQP 和 Rabbit MQ 的启动器 |
|
使用 Spring AOP 和 AspectJ 进行面向方面的编程的启动器 |
|
使用 Apache Artemis 进行 JMS 消息传递的启动器 |
|
使用 Spring Batch 的启动器 |
|
使用 Spring Framework 的缓存支持的启动器 |
|
使用 Cassandra 分布式数据库和 Spring Data Cassandra 的启动器 |
|
使用 Cassandra 分布式数据库和 Spring Data Cassandra Reactive 的启动器 |
|
使用 Couchbase 文档型数据库和 Spring Data Couchbase 的启动器 |
|
使用 Couchbase 文档型数据库和 Spring Data Couchbase Reactive 的启动器 |
|
使用 Elasticsearch 搜索和分析引擎以及 Spring Data Elasticsearch 的启动器 |
|
使用 Spring Data JDBC 的启动器 |
|
使用 Spring Data JPA 和 Hibernate 的启动器 |
|
使用 Spring Data LDAP 的启动器 |
|
使用 MongoDB 文档型数据库和 Spring Data MongoDB 的启动器 |
|
使用 MongoDB 文档型数据库和 Spring Data MongoDB Reactive 的启动器 |
|
使用 Neo4j 图数据库和 Spring Data Neo4j 的启动器 |
|
使用 Spring Data R2DBC 的启动器 |
|
使用 Redis 键值数据存储,Spring Data Redis 和 Lettuce 客户端的启动器 |
|
使用 Redis 键值数据存储,Spring Data Redis Reactive 和 Lettuce 客户端的启动器 |
|
使用 Spring Data REST 和 Spring MVC 通过 REST 暴露 Spring Data 存储库的启动器 |
|
使用 FreeMarker 视图构建 MVC Web 应用程序的启动器 |
|
使用 Spring GraphQL 构建 GraphQL 应用程序的启动器 |
|
使用 Groovy 模板视图构建 MVC Web 应用程序的启动器 |
|
使用 Spring MVC 和 Spring HATEOAS 构建基于超媒体的 RESTful Web 应用程序的启动器 |
|
使用 Spring Integration 的启动器 |
|
使用 JDBC 和 HikariCP 连接池的启动器 |
|
使用 JAX-RS 和 Jersey 构建 RESTful Web 应用程序的启动器。作为 |
|
使用 jOOQ 通过 JDBC 访问 SQL 数据库的启动器。作为 |
|
用于读取和写入 json 的启动器。 |
|
用于使用 Java Mail 和 Spring Framework 的电子邮件发送支持的启动器。 |
|
用于使用 Mustache 视图构建 Web 应用程序的启动器。 |
|
用于使用 Spring Authorization Server 功能的启动器。 |
|
用于使用 Spring Security 的 OAuth2/OpenID Connect 客户端功能的启动器。 |
|
用于使用 Spring Security 的 OAuth2 资源服务器功能的启动器。 |
|
用于使用 Spring for Apache Pulsar 的启动器。 |
|
用于使用 Spring for Apache Pulsar Reactive 的启动器。 |
|
用于使用 Quartz 调度程序的启动器。 |
|
用于构建 RSocket 客户端和服务器的启动器。 |
|
用于使用 Spring Security 的启动器。 |
|
用于使用包括 JUnit Jupiter、Hamcrest 和 Mockito 在内的库测试 Spring Boot 应用程序的启动器。 |
|
用于使用 Thymeleaf 视图构建 MVC Web 应用程序的启动器。 |
|
用于使用 Java Bean Validation 和 Hibernate Validator 的启动器。 |
|
用于使用 Spring MVC 构建 Web(包括 RESTful)应用程序的启动器。使用 Tomcat 作为默认的嵌入式容器。 |
|
用于使用 Spring Web Services 的启动器。 |
|
用于使用 Spring Framework 的 Reactive Web 支持构建 WebFlux 应用程序的启动器。 |
|
使用 Spring 框架的 MVC WebSocket 支持构建 WebSocket 应用程序的入门程序 |
除了应用程序启动器之外,还可以使用以下启动器添加生产就绪功能
名称 | 描述 |
---|---|
使用 Spring Boot 的 Actuator 的启动器,它提供生产就绪的功能来帮助您监控和管理应用程序 |
最后,Spring Boot 还包括以下启动器,如果您想排除或替换特定技术方面,可以使用这些启动器
名称 | 描述 |
---|---|
使用 Jetty 作为嵌入式 servlet 容器的启动器。是 |
|
使用 Log4j2 进行日志记录的启动器。是 |
|
使用 Logback 进行日志记录的启动器。默认的日志记录启动器 |
|
使用 Reactor Netty 作为嵌入式反应式 HTTP 服务器的启动器。 |
|
使用 Tomcat 作为嵌入式 servlet 容器的启动器。由 |
|
使用 Undertow 作为嵌入式 servlet 容器的启动器。是 |
要了解如何交换技术方面,请参阅有关 交换 Web 服务器 和 日志记录系统 的操作说明文档。
有关社区贡献的更多启动器的列表,请参阅 GitHub 上 spring-boot-starters 模块中的 README 文件。
|