SpringBoot 基础知识汇总
Posted Doker 多克
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SpringBoot 基础知识汇总相关的知识,希望对你有一定的参考价值。
一、环境准备
Java:Spring Boot 3.0.2 需要 Java 17,并且与 Java 19 兼容
Maven:Apache Maven 3.5 或更高版本兼容
二、启动器
以下应用程序启动器由 Spring Boot 在该组下提供:org.springframework.boot
表 1.Spring 引导应用程序启动器
名字 | 描述 |
spring-boot-starter | 核心启动器,包括自动配置支持、日志记录和 YAML |
spring-boot-starter-amqp | 使用Spring AMQP和Rabbit MQ的入门 |
spring-boot-starter-aop | 使用Spring AOP和AspectJ进行面向方面的编程的入门器 |
spring-boot-starter-artemis | 使用 Apache Artemis 的 JMS 消息传递入门 |
spring-boot-starter-batch | 使用弹簧批处理的启动器 |
spring-boot-starter-cache | 使用 Spring 框架缓存支持的入门工具 |
spring-boot-starter-data-cassandra | 使用 Cassandra 分布式数据库和 Spring Data Cassandra 的入门 |
spring-boot-starter-data-cassandra-reactive | 使用 Cassandra 分布式数据库和 Spring Data Cassandra Reactive 的入门 |
spring-boot-starter-data-couchbase | 使用Couchbase面向文档的数据库和Spring Data Couchbase的入门 |
spring-boot-starter-data-couchbase-reactive | 用于使用 Couchbase 面向文档的数据库和 Spring Data Couchbase Reactive 的入门 |
spring-boot-starter-data-elasticsearch | 使用Elasticsearch搜索和分析引擎以及Spring Data Elasticsearch的入门工具 |
spring-boot-starter-data-jdbc | 使用Spring Data JDBC的入门器 |
spring-boot-starter-data-jpa | 将 Spring Data JPA 与 Hibernate 一起使用的入门程序 |
spring-boot-starter-data-ldap | 使用Spring Data LDAP的入门 |
spring-boot-starter-data-mongodb | 使用MongoDB面向文档的数据库和Spring Data MongoDB的入门 |
spring-boot-starter-data-mongodb-reactive | 使用MongoDB面向文档的数据库和Spring Data MongoDB反应式的入门 |
spring-boot-starter-data-neo4j | 使用 Neo4j 图形数据库和 Spring Data Neo4j 的入门 |
spring-boot-starter-data-r2dbc | 使用弹簧数据R2DBC的入门器 |
spring-boot-starter-data-redis | 将 Redis 键值数据存储与 Spring Data Redis 和 Lettuce 客户端一起使用的入门 |
spring-boot-starter-data-redis-reactive | 将 Redis 键值数据存储与 Spring Data Redis 反应式和生菜客户端一起使用的入门 |
spring-boot-starter-data-rest | 使用Spring Data REST通过REST公开Spring Data Repository的入门程序 |
spring-boot-starter-freemarker | 使用 FreeMarker 视图构建 MVC Web 应用程序的入门器 |
spring-boot-starter-graphql | 使用 Spring GraphQL 构建 GraphQL 应用程序的入门器 |
spring-boot-starter-groovy-templates | 使用 Groovy 模板视图构建 MVC Web 应用程序的入门工具 |
spring-boot-starter-hateoas | 使用Spring MVC和Spring HATEOAS构建基于超媒体的RESTful Web应用程序的入门 |
spring-boot-starter-integration | 使用弹簧集成的启动器 |
spring-boot-starter-jdbc | 将 JDBC 与 HikariCP 连接池一起使用的入门 |
spring-boot-starter-jersey | 使用 JAX-RS 和 Jersey 构建 RESTful Web 应用程序的入门工具。弹簧启动启动网的替代方案 |
spring-boot-starter-jooq | 使用 jOOQ 通过 JDBC 访问 SQL 数据库的入门工具。spring-boot-starter-data-jpa 或 spring-boot-starter-jdbc 的替代方案 |
spring-boot-starter-json | 用于读取和写入 json 的入门器 |
spring-boot-starter-mail | 使用Java Mail和Spring Framework的电子邮件发送支持的入门 |
spring-boot-starter-mustache | 使用 Mustache 视图构建 Web 应用程序的入门器 |
spring-boot-starter-oauth2-client | 使用Spring Security的OAuth2 / OpenID Connect客户端功能的入门 |
spring-boot-starter-oauth2-resource-server | 使用Spring Security的OAuth2资源服务器功能的入门 |
spring-boot-starter-quartz | 使用石英调度程序的入门器 |
spring-boot-starter-rsocket | 用于构建 RSocket 客户端和服务器的入门器 |
spring-boot-starter-security | 使用弹簧安全性的入门 |
spring-boot-starter-test | 用于测试Spring Boot应用程序的入门器,包括JUnit Jupiter,Hamcrest和Mockito等库 |
spring-boot-starter-thymeleaf | 使用 Thymeleaf 视图构建 MVC Web 应用程序的入门器 |
spring-boot-starter-validation | 将 Java Bean Validation 与 Hibernate Validator 结合使用的入门程序 |
spring-boot-starter-web | 用于构建Web的入门工具,包括使用Spring MVC构建Web(包括RESTful)的应用程序。使用 Tomcat 作为默认的嵌入式容器 |
spring-boot-starter-web-services | 使用 Spring Web 服务的入门器 |
spring-boot-starter-webflux | 使用 Spring Framework 的响应式 Web 支持构建 WebFlux 应用程序的入门工具 |
spring-boot-starter-websocket | 使用Spring Framework的MVC WebSocket支持构建WebSocket应用程序的入门工具 |
除了应用程序启动器之外,以下启动器还可用于添加生产就绪功能:
表 2.Springboot启动器
名字 | 描述 |
spring-boot-starter-actuator | 使用Spring Boot执行器的入门,该执行器提供生产就绪功能,可帮助您监视和管理应用程序 |
最后,Spring Boot 还包括以下启动器,如果要排除或交换特定的技术方面,可以使用它们:
表 3.Springboot技术启动器
名字 | 描述 |
spring-boot-starter-jetty | 使用 Jetty 作为嵌入式 servlet 容器的入门工具。弹簧启动启动器-雄猫的替代品 |
spring-boot-starter-log4j2 | 使用 Log4j2 进行日志记录的入门程序。弹簧引导启动日志记录的替代方案 |
spring-boot-starter-logging | 使用回日志进行日志记录的启动器。默认日志记录启动器 |
spring-boot-starter-reactor-netty | 使用 Reactor Netty 作为嵌入式反应式 HTTP 服务器的入门程序。 |
spring-boot-starter-tomcat | 使用 Tomcat 作为嵌入式 servlet 容器的入门工具。spring-boot-starter-web 使用的默认 servlet 容器启动器 |
spring-boot-starter-undertow | 使用 Undertow 作为嵌入式 servlet 容器的入门工具。弹簧启动启动器-雄猫的替代品 |
要了解如何交换技术方面,请参阅交换 Web 服务器和日志记录系统的操作文档。
三、配置类
Spring Boot 倾向于基于 Java 的配置。 尽管SpringApplication 可以与 XML 源一起使用,但我们通常建议将主源设置为单个类@Configuration。 通常,用@Configuration定义一个有main方法的类。
3.1. 导入其他配置类
当你不需要把所有的东西都放在一个Class里时。 @Import注释可用于导入其他配置类。或者,您可以使用@ComponentScan 自动加载所有 Spring 组件,包括类。
@Import( 类名.class , 类名.class... )
public class Appcalss
3.2自动配置
Spring 引导自动配置会尝试根据您添加的 jar 依赖项自动配置 Spring 应用程序。 例如,如果位于您的类路径上,并且您尚未手动配置任何数据库连接 bean,则 Spring 引导会自动配置内存数据库。
@EnableAutoConfiguration:启用Spring Boot的自动配置机制,类似在java代码中自动import,属于自动导入
@SpringBootConfiguration(proxyBeanMethods = false)
@EnableAutoConfiguration
@Import( SomeConfiguration.class, AnotherConfiguration.class )
public class MyApplication
public static void main(String[] args)
SpringApplication.run(MyApplication.class, args);
禁用特定的自动配置类
如果发现正在应用不需要的特定自动配置类,则可以使用 的 exclude 属性来禁用它们,如以下示例所示:@SpringBootApplication
@SpringBootApplication(exclude = DataSourceAutoConfiguration.class )
public class MyApplication
四、使用@SpringBootApplication注释
许多 Spring Boot 开发人员喜欢他们的应用程序使用自动配置、组件扫描并能够在他们的“应用程序类”上定义额外的配置。 单个注释可用于启用这三个功能,即:@SpringBootApplication
@EnableAutoConfiguration:启用 Spring 启动的自动配置机制
@ComponentScan:在应用程序所在的包上启用扫描(请参阅最佳实践)@Component)
@SpringBootConfiguration:在上下文中启用额外 Bean 的注册或导入其他配置类。 Spring 标准的替代方案,可帮助在集成测试中进行配置检测。
// Same as @SpringBootConfiguration @EnableAutoConfiguration @ComponentScan
@SpringBootApplication
public class MyApplication
public static void main(String[] args)
SpringApplication.run(MyApplication.class, args);
五、开发一个 SpringBoot应用程序
在开始之前,请打开终端并运行以下命令以确保已安装有效版本的 Java 和 Maven:
$ java -version
openjdk version "17.0.4.1" 2022-08-12 LTS
OpenJDK Runtime Environment (build 17.0.4.1+1-LTS)
OpenJDK 64-Bit Server VM (build 17.0.4.1+1-LTS, mixed mode, sharing)
mvn -v
Apache Maven 3.8.5 (3599d3414f046de2324203b78ddcf9b5e4388aa0)
Maven home: usr/Users/developer/tools/maven/3.8.5
Java version: 17.0.4.1, vendor: BellSoft, runtime: /Users/developer/sdkman/candidates/java/17.0.4.1-librca
1、创建 POM
我们需要从创建一个 Maven 文件开始。
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.example</groupId>
<artifactId>myproject</artifactId>
<version>0.0.1-SNAPSHOT</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>3.0.2</version>
</parent>
<!-- Additional lines to be added here... -->
</project>
2、添加类路径依赖
在此之前,我们可以通过运行以下命令来查看我们当前拥有的内容:spring-boot-starter-web
$ mvn dependency:tree
[INFO] com.example:myproject:jar:0.0.1-SNAPSHOT
由于我们正在开发一个 Web 应用程序,因此我们添加一个依赖项
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
3、编写代码
为了完成我们的应用程序,我们需要创建一个 Java 文件。 默认情况下,Maven 从 编译源代码,因此您需要创建该目录结构,然后添加一个名为以包含以下代码的文件:src/main/javasrc/main/java/MyApplication.java
@RestController
@SpringBootApplication
public class MyApplication
@RequestMapping("/")
String home()
return "Hello World!";
public static void main(String[] args)
SpringApplication.run(MyApplication.class, args);
@RestController:相当于@ResponseBody + @Controller,@Controller注解表示后,该类将会被spring管理,@ResponseBody注解标识后,响应数据可以是文本或者JSON数据类型
@RequestMapping:是一个用来处理请求地址映射的注解,可用于映射一个请求或一个方法,可以用在类或方法上。
六、Tracing
Spring Boot 提供依赖管理和自动配置Micrometer Tracing,这是常用信息监控库 。
Spring Boot 为以下跟踪器提供自动配置:
我们需要一个可用于开始跟踪的示例应用程序。 就我们的目的而言,“入门.html部分中介绍的简单”Hello World!“Web 应用程序就足够了。 我们将使用OpenTelemetry跟踪器与Zipkin作为跟踪后端。
回顾一下,我们的主要应用程序代码如下所示:
@RestController
@SpringBootApplication
public class MyApplication
privatestaticfinal Log logger = LogFactory.getLog(MyApplication.class);
@RequestMapping("/")
String home()
logger.info("home() has been called");
return"Hello World!";
public static void main(String[] args)
SpringApplication.run(MyApplication.class, args);
该方法中添加了一个记录器语句,稍后会很重要。home()
现在我们必须添加以下依赖项:
org.springframework.boot:spring-boot-starter-actuator
io.micrometer:micrometer-tracing-bridge-otel- 这是将千分尺观测 API 桥接到开放遥测所必需的。
io.opentelemetry:opentelemetry-exporter-zipkin- 需要向 Zipkin 报告痕迹。
添加以下应用程序属性:
management.tracing.sampling.probability=1.0
默认情况下,Spring Boot 仅对 10% 的请求进行采样,以防止跟踪后端不堪重负。 此属性将其切换为 100%,以便将每个请求发送到跟踪后端。
为了收集和可视化跟踪,我们需要一个正在运行的跟踪后端。 我们在这里使用 Zipkin 作为我们的跟踪后端。 Zipkin 快速入门指南提供了如何在本地启动 Zipkin 的说明。
Zipkin 运行后,您可以启动应用程序。
七、日志记录
Spring Boot 没有强制性的日志记录依赖项,除了通常由 Spring Framework 模块提供的 Commons Logging API。 要使用 Logback,您需要将其包含在类路径中。 推荐的方法是通过启动器,这完全取决于 . 对于 Web 应用程序,您只需要 ,因为它以传递方式依赖于日志记录启动器。 如果使用 Maven,则以下依赖项会为您添加日志记录:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
Spring Boot 有一个抽象,它试图根据类路径的内容配置日志记录。 如果 Logback 可用,则它是首选。LoggingSystem
如果需要对日志记录进行的唯一更改是设置各种记录器的级别,则可以使用“logging.level”前缀执行此操作,如以下示例所示:application.properties
logging.level.org.springframework.web=debug
logging.level.org.hibernate=error
除了控制台之外,您还可以使用 设置要将日志写入的文件的位置。要配置日志记录系统的更细粒度设置,您需要使用相关支持的本机配置格式。 默认情况下,Spring 引导从系统的默认位置(例如 Logback)选取本机配置,但您可以使用该属性设置配置文件的位置。
1、为日志记录配置回日志
如果需要将自定义应用于 logback,而不是可以使用 实现的自定义项,则需要添加标准 logback 配置文件。 您可以将文件添加到类路径的根目录中,以便进行回查
Spring 引导提供了许多登录配置,这些配置可以在您自己的配置中。 这些包括旨在允许重新应用某些常见的 Spring 引导约定。included
以下文件在 下提供:org/springframework/boot/logging/logback/
defaults.xml- 提供转换规则、模式属性和常用记录器配置。
console-appender.xml- 使用 .ConsoleAppenderCONSOLE_LOG_PATTERN
file-appender.xml- 使用适当的设置添加 和。RollingFileAppenderFILE_LOG_PATTERNROLLING_FILE_NAME_PATTERN
此外,还提供了旧文件以与早期版本的 Spring Boot 兼容。base.xml
典型的自定义文件如下所示:logback.xml
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<include resource="org/springframework/boot/logging/logback/defaults.xml"/>
<include resource="org/springframework/boot/logging/logback/console-appender.xml" />
<root level="INFO">
<appender-ref ref="CONSOLE" />
</root>
<logger name="org.springframework.web" level="DEBUG"/>
</configuration>
您的登录配置文件还可以利用负责为您创建的系统属性:
$PID:当前进程 ID。
$LOG_FILE:是否在引导的外部配置中设置。logging.file.name
$LOG_PATH:是否在 Boot 的外部配置中设置了(表示日志文件所在的目录)。logging.file.path
$LOG_EXCEPTION_CONVERSION_WORD:是否在引导的外部配置中设置。logging.exception-conversion-word
$ROLLING_FILE_NAME_PATTERN:是否在引导的外部配置中设置。logging.pattern.rolling-file-name
Spring Boot 还通过使用自定义 Logback 转换器在控制台上(但不在日志文件中)提供了一些不错的 ANSI 颜色终端输出
2、配置 log4j 用于日志记录
Spring Boot 支持 Log4j 2 进行日志记录配置,如果它位于类路径上。 如果使用启动器来组装依赖项,则必须排除 Logback,然后改为包含 Log4j 2。 如果您不使用启动器,除了 Log4j 2 之外,您还需要(至少)提供。
推荐的路径是通过启动器,即使它需要一些摇晃。 以下示例显示了如何在 Maven 中设置启动器:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>
八、配置 SSL
可以通过设置各种属性(通常在 或 中)以声明方式配置 SSL。 以下示例显示如何使用 Java 密钥库文件设置 SSL 属性:server.ssl.*
server.port=8443
server.ssl.key-store=classpath:keystore.jks
server.ssl.key-store-password=secret
server.ssl.key-password=another-secret
以上是关于SpringBoot 基础知识汇总的主要内容,如果未能解决你的问题,请参考以下文章