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-jpaspring-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

  • @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 基础知识汇总的主要内容,如果未能解决你的问题,请参考以下文章

知识点-Spring Boot 统一异常处理汇总

云原生Spring Cloud微服务学习路线汇总

springboot整合redis异常汇总

Spring面试题汇总3:SpringBoot面试题及答案整理

转载--springboot 开发入门,及问题汇总

springboot整合logback集成elk实现日志的汇总分析统计和检索功能