环境&工具 | 版本(or later) |
---|---|
SpringBoot | 3.0.5+ |
IDEA | 2021.2.1+ |
Java | 17+ |
Maven | 3.5+ |
Tomcat | 10.0+ |
Servlet | 5.0+ |
GraalVM Community | 22.3+ |
Native Build Tools | 0.9.19+ |
SpringBoot 帮我们简单、快速地创建一个独立的、生产级别的 Spring 应用(说明:SpringBoot底层是Spring)
大多数 SpringBoot 应用只需要编写少量配置即可快速整合 Spring 平台以及第三方技术
特性:
快速创建独立 Spring 应用
直接嵌入Tomcat、Jetty or Undertow(无需部署 war 包)【Servlet容器】
重点:提供可选的starter,简化应用整合
重点:按需自动配置 Spring 以及 第三方库
提供生产级特性:如 监控指标、健康检查、外部化配置等
无代码生成、无xml
总结:简化开发,简化配置,简化整合,简化部署,简化监控,简化运维。
场景:浏览器发送/hello请求,返回"Hello,Spring Boot 3!"
maven 项目
<parent>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-starter-parentartifactId>
<version>3.0.5version>
parent>
场景启动器
<dependencies>
<dependency>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-starter-webartifactId>
dependency>
dependencies>
@SpringBootApplication //这是一个SpringBoot应用
public class MainApplication {
public static void main(String[] args) {
SpringApplication.run(MainApplication.class,args);
}
}
@RestController
public class HelloController {
@GetMapping("/hello")
public String hello(){
return "Hello,Spring Boot 3!";
}
}
默认启动访问: localhost:8080
<build>
<plugins>
<plugin>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-maven-pluginartifactId>
plugin>
plugins>
build>
mvn clean package
把项目打成可执行的jar包
java -jar demo.jar
启动项目
导入相关的场景,拥有相关的功能。场景启动器:场景一导入,万物皆就绪。
默认支持的所有场景:https://docs.spring.io/spring-boot/docs/current/reference/html/using.html#using.build-systems.starters
spring-boot-starter-*
*-spring-boot-starter
无需编写任何配置,直接开发业务
application.properties
:
打包为可执行的jar包。
linux服务器上有java环境。
修改配置(外部放一个application.properties文件)、监控、健康检查。
一键创建好整个项目结构
思考:
1、为什么导入starter-web
所有相关依赖都导入进来?
2、为什么版本号都不用写?
spring-boot-starter-parent
spring-boot-dependencies
mysql-connector-j
3、自定义版本号
利用maven的就近原则
properties
标签中声明父项目用的版本属性的key4、第三方的jar包
<dependency>
<groupId>com.alibabagroupId>
<artifactId>druidartifactId>
<version>1.2.16version>
dependency>
自动配置的 Tomcat、SpringMVC 等
public static void main(String[] args) {
//java10: 局部变量类型的自动推断
var ioc = SpringApplication.run(MainApplication.class, args);
//1、获取容器中所有组件的名字
String[] names = ioc.getBeanDefinitionNames();
//2、挨个遍历:
// dispatcherServlet、beanNameViewResolver、characterEncodingFilter、multipartResolver
// SpringBoot把以前配置的核心组件现在都给我们自动配置好了。
for (String name : names) {
System.out.println(name);
}
}
默认的包扫描规则
@SpringBootApplication
标注的类就是主程序类@ComponentScan("com.atguigu")
直接指定扫描的路径配置默认值
ServerProperties
绑定了所有Tomcat服务器有关的配置MultipartProperties
绑定了所有文件上传相关的配置按需加载自动配置
spring-boot-starter-web
spring-boot-starter
,是所有starter
的starter
,基础核心starterspring-boot-starter
导入了一个包 spring-boot-autoconfigure
。包里面都是各种场景的AutoConfiguration
自动配置类spring-boot-autoconfigure
这个包,但是不是全都开启的。总结: 导入场景启动器、触发 spring-boot-autoconfigure
这个包的自动配置生效、容器中就会具有相关场景的功能
思考:
1、SpringBoot怎么实现导一个starter
、写一些简单配置,应用就能跑起来,我们无需关心整合
2、为什么Tomcat的端口号可以配置在application.properties
中,并且Tomcat
能启动成功?
3、导入场景后哪些自动配置能生效?
自动配置流程细节梳理:
1、导入starter-web
:导入了web开发场景
starter-json
、starter-tomcat
、springmvc
spring-boot-starter
,核心场景启动器。spring-boot-autoconfigure
包。spring-boot-autoconfigure
里面囊括了所有场景的所有配置。spring-boot-autoconfigure
下写好的所有配置类。(这些配置类给我们做了整合操作),默认只扫描主程序所在的包。2、程序:@SpringBootApplication
1、@SpringBootApplication
由三个注解组成@SpringBootConfiguration
、@EnableAutoConfiguratio
、@ComponentScan
2、SpringBoot默认只能扫描自己主程序所在的包及其下面的子包,扫描不到 spring-boot-autoconfigure
包中官方写好的配置类
3、@EnableAutoConfiguration
:SpringBoot 开启自动配置的核心。
@Import(AutoConfigurationImportSelector.class)
提供功能:批量给容器中导入组件。spring-boot-autoconfigure
下 META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports
文件指定的autoconfigure
包下的142 xxxxAutoConfiguration
类导入进来(自动配置类)142
个自动配置类4、按需生效:
142
个自动配置类都能生效@ConditionalOnxxx
,只有条件成立,才能生效3、xxxxAutoConfiguration
自动配置类
@EnableConfigurationProperties(ServerProperties.class)
,用来把配置文件中配的指定前缀的属性值封装到 xxxProperties
属性类中server
开头的。配置都封装到了属性类中。xxxProperties
。xxxProperties
都是和配置文件绑定。4、写业务,全程无需关心各种整合(底层这些整合写好了,而且也生效了)
核心流程总结:
1、导入starter
,就会导入autoconfigure
包。
2、autoconfigure
包里面 有一个文件 META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports
,里面指定的所有启动要加载的自动配置类
3、@EnableAutoConfiguration 会自动的把上面文件里面写的所有自动配置类都导入进来。xxxAutoConfiguration 是有条件注解进行按需加载
4、xxxAutoConfiguration
给容器中导入一堆组件,组件都是从 xxxProperties
中提取属性值
5、xxxProperties
又是和配置文件进行了绑定
效果:导入starter
、修改配置文件,就能修改底层行为。
框架的框架、底层基于Spring。能调整每一个场景的底层行为。100%项目一定会用到底层自定义
理解自动配置原理:导入starter –> 生效xxxxAutoConfiguration --> 组件 –> xxxProperties --> 配置文件
理解其他框架底层:拦截器
可以随时定制化任何组件:配置文件、自定义组件
普通开发:导入starter
,Controller、Service、Mapper、偶尔修改配置文件
高级开发:自定义组件、自定义配置、自定义starter
核心:
最佳实战:
选场景,导入到项目
写配置,改配置文件关键项
分析这个场景给我们导入了哪些能用的组件
整合redis:
选场景:spring-boot-starter-data-redis
写配置:
@EnableConfigurationProperties(RedisProperties.class)
分析组件:
RedisAutoConfiguration
给容器中放了 StringRedisTemplate
StringRedisTemplate
定制化
spring-boot-starter-data-redis
写配置:
@EnableConfigurationProperties(RedisProperties.class)
分析组件:
RedisAutoConfiguration
给容器中放了 StringRedisTemplate
StringRedisTemplate
定制化
StringRedisTemplate