基本概念

  • SpringBoot的优点:

    • 可以创建独立的Spring应用
    • SpringBoot嵌入Tomcat,JettyUnsertow, 不需要部署war文件
    • 根据需要通过maven获取starter
    • Spring进行自动配置
    • 提供生产就绪型功能,包括指标,健康检查和外部配置

SpringBoot父项目

<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>1.5.9.RELEASE</version>
<relativePath>../../spring-boot-dependencies</relativePath>
</parent>
  • 管理SpringBoot应用里面所有的依赖版本,这样以后导入依赖默认不需要写版本号,可以统一管理开发版本(没有在dependencies里面管理的依赖才需要声明版本号)

spring-boot-starter

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
  • spring-boot-starter: springboot场景启动器
  • spring-boot-starter-web: 导入web模块正常运行所依赖的组件
  • SpringBoot将所有的功能场景都抽取出来,做成各个starter启动器,只需要在项目的pom.xml中引入这些starter依赖,相关场景的所有依赖都会被导入进来。

@SpringBootApplication

  • @SpringBootApplication:标注在SpringBoot的主配置类,SpringBoot就会运行这个类的main方法来启动SpringBoot运用。
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@SpringBootConfiguration //SpringBoot配置类,类似于配置文件。配置类也是容器中的组件。标注在类上标明是一个SpringBoot配置类
@EnableAutoConfiguration //开启SpringBoot自动配置功能
@ComponentScan(
excludeFilters = {@Filter(
type = FilterType.CUSTOM,
classes = {TypeExcludeFilter.class}
), @Filter(
type = FilterType.CUSTOM,
classes = {AutoConfigurationExcludeFilter.class}
)}
)
public @interface SpringBootApplication {
@AliasFor(
annotation = EnableAutoConfiguration.class,
attribute = "exclude"
)
Class<?>[] exclude() default {}; @AliasFor(
annotation = EnableAutoConfiguration.class,
attribute = "excludeName"
)
String[] excludeName() default {}; @AliasFor(
annotation = ComponentScan.class,
attribute = "basePackages"
)
String[] scanBasePackages() default {}; @AliasFor(
annotation = ComponentScan.class,
attribute = "basePackageClasses"
)
Class<?>[] scanBasePackageClasses() default {};
}
  • @SpringBootConfiguration: SpringBoot配置类,类似于配置文件。配置类也是容器中的组件。标注在类上标明是一个SpringBoot配置类
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Configuration // 表明该类是一个Spring的配置类
public @interface SpringBootConfiguration {
@AliasFor(
annotation = Configuration.class
)
boolean proxyBeanMethods() default true;
}
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Component // 表明该类是Spring的一个组件
public @interface Configuration {
@AliasFor(
annotation = Component.class
)
String value default ""; boolean proxyBeanMethods() default true;
}
  • @EnableAutoConfiguration: 开启SpringBoot自动配置功能

package org.springframework.boot.autoconfigure; import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import org.springframework.context.annotation.Import; @Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@AutoConfigurationPackage
@Import({AutoConfigurationImportSelector.class})
public @interface EnableAutoConfiguration {
String ENABLED_OVERRIDE_PROPERTY = "spring.boot.enableautoconfiguration"; Class<?>[] exclude() default {}; String[] excludeName() default {};
}
  • @AutoConfigurationPackage: 自动配置包,通过 @Import({Registrar.class}) 完成,通过查看Registrar源码发现将主配置类即 @SpringBootApplication标注的类的所在包及所有子包里面的所有组件扫描到Spring容器中
  • 其中,@Import是Spring的底层注解,给容器导入一个组件,导入的组件由Registrar.class来指定。
  • AutoConfigurationImportSelector:导入组件的选择器,将所有需要导入的组件以全类名的方式返回,这样组件就会被添加到容器中
    • 会给容器中导入自动配置类:就是给容器中导入场景所有的组件并配置好.这样就不用手动编写配置并注入功能组件
  • SpringFactoriesLoader.loadFactoryNames(EnableAutoConfiguration.class,classLoader):
    • 从类路径下的META-INF/spring.factories中获取EnableAutoConfiguration指定的值
  • 过程总结:
    • SpringBoot在启动的时候从类路径下的META-INF/spring.factories中获取EnableAutoConfiguration指定的值
    • 将这些值作为自动配置类导入到容器中,自动配置类就会生效,进行配置工作。
  • J2EE的整体整合解决方案和自动配置都在spring-boot-autoconfigure-2.0.1.RELEASE.jar中

在SpringBoot项目中的resources文件夹:

  • static:保存所有静态资源,例如 js,css,images
  • templates:保存所有的模板页面。在SpringBoot中默认jar包使用的是嵌入式tomcat,默认不支持jsp页面。可以使用模板引擎:freemarker,thymeleaf
  • application.properties:SpringBoot应用的配置文件,可以修改一些默认设置

SpringBoot配置

配置文件

SpringBoot使用一个全局配置文件,配置文件名是固定的:

  • application.properties
  • application.yml
  • 配置文件作用:修改SpringBoot自动配置的默认值。

yml

  • yml:(YAML Ain't Markup Language)以数据为中心,比json、xml等更适合做配置文件。
YAML基本语法
  • key: value(表示一对键值对。value前面必须要有空格。)
  • 空格缩进来表示层级关系,只要是左对齐的一列数据,都是同一个层级的

    1.缩进时不允许使用Tab键,只允许使用空格

    2.缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
  • 属性和值是大小写敏感
  • 值的写法:
    • 字面量:普通的值(数字,字符串,布尔值)
  • key:value :字面量直接书写。字符串默认不加引号。
  • 单引号-转义字符会作为普通字符串输出
  • 双引号-转义字符会转变成格式
  • 对象、Map(属性和值,键值对):
    • 对象还是key: value的方式
friends:
lastName: Chova
firstName: Vea

行内写法:

friends: {lastName: Chova,firstName: Vea}
  • 数组(List、Set)

    • - 值表示数组中的元素
pets:
- dog
- cat
- pig

行内写法:

pets: [dog,cat,pig]

@Value获取值和@ConfigurationProperties获取值比较

@Value @ConfigurationProperties
功能 在属性上一个一个指定注入 批量注入配置文件中的属性
松散绑定(松散语法) 不支持 支持
SpEL 支持 不支持
JSR303数据校验 不支持 支持
复杂类型封装 不支持 支持
  • 如果我们只是在某个业务逻辑中需要获取一下配置文件的某项值,就使用@Value
  • 如果JavaBean需要和配置文件进行映射,就使用@ConfigurationProperties

配置文件注入值数值校验(JSR303)

  • 必须要用 @ConfigurationProperties
  • JSR303数据校验:@Validate-@Email

@PropertySource和@ImportResource

  • @PropertySource:加载指定的配置文件
@PropertySource(value = {"classpath:person.properties"})
  • @ImportResource:导入Spring的配置文件,让配置文件的内容生效
@ImportResource(locations={"classpath:beans.xml"})
  • SpringBoot推荐给容器中添加组件的方式: 推荐使用 全注解 的方式

    1.配置类 --- Spring配置文件

    2.使用 @Bean在配置类中为容器中添加组件

配置文件占位符

  • RandomValuePropertySource:配置文件中可以使用随机数
1.${random.value}
2.${random.int}
3.${random.int(10)}
4.${random.int[1024,65536]}
  • 属性配置占位符

    1.可以在配置文件中引用前面配置过的属性(优先级前面配置过的这里都能用)

    2.${app.name:默认值}来指定找不到属性值时的默认值

Profile

  • 多Profile文件

    1.在写配置文件的时候,文件名可以是:application-{profile}.properties/yml

    2.默认使用application.properties的配置
  • yml支持多文档块方式
    • 用"- - -"划分文档块
---

激活指定Profile

1.在主配置文件application.properties中指定激活:

spring.profiles.active=dev

2.命令行激活:(Program arguments)

--spring.profiles.active=dev

3.虚拟机参数激活:(VM options)

-Dspring.profiles.active=dev

配置文件加载位置

  • SpringBoot启动会扫描以下位置的application.properties或者application.yml文件作为SpringBoot的默认配置文件
  1. file:./config/
  2. file:./
  3. classpath:/config
  4. classpath:/
  • 以上按照优先级从高到低,所有文件都会被加载,互补配置。高优先级内容会覆盖低优先级内容。
  • 可以通过配置- -spring.config.location来改变默认配置位置:项目打包好以后,使用命令行参数的形式,启动项目的时候来指定配置文件的新位置,指定的配置文件和默认加载的配置文件会共同起作用,互补配置。

外部配置的加载顺序

  • SpringBoot支持多种外部配置方式,优先级如下:

    1.命令行参数(- -,多个命令用空格分开)

    2.来自java:comp/env的JNDI属性

    3.Java系统属性(System.getProperties())

    4.操作系统环境变量

    5.RandomValuePropertySource配置的random.*属性值

    由jar包外部向jar包内进行寻找:

    优先加载带profile的:

    6.jar包外部的application-{profile}.properties/yml(带spring.profile)配置文件

    7.jar包内部的application-{profile}.properties/yml(带spring.profile)配置文件

    然后加载不带Profile的:

    8.jar包外部的application-{profile}.properties/yml(不带spring.profile)配置文件

    9.jar包内部的application-{profile}.properties/yml(不带spring.profile)配置文件

    10.@Configuration注解类上的@PropertySource

    11.通过SpringApplication.setDefaultProperties指定的默认属性

自动配置原理

  • SpringBoot启动时加载主配置类,开启了自动配置功能 @EnableAutoConfiguration
  • @EnableAutoConfiguration作用:利用EnableAutoConfigurationImportSelector给容器导入组件。

    具体实现可以查看selectImports() 方法:
List<String> configurations = this.getCandidateConfigurations(annotationMetadata, attributes);获取候选的配置
SpringFactoriesLoader.loadFactoryNames();扫描所有jar包类路径下:META-INF/spring.factories。把扫描到的这些文件的内容包装成properties对象,从properties中获取到EnableAutoConfiguration.class(类名)类的值,然后把它们添加在容器中

将类路径下META-INF/spring.factories里面配置的所有EnableAutoConfiguration的值加入到了容器中。

  • 每一个自动配置类进行自动配置功能。
@Configuration	// 表示这是一个配置类,类似配置文件,可以给容器中添加组件
@EnableConfigurationProperties({HttpProperties.class}) // 启用指定类的ConfigurationProperties(从配置文件中获取指定的值和bean的属性进行绑定)功能
@ConditionalOnWebApplication( // Spring底层@conditional注解,根据不同的条件,如果满足指定的条件,整个配置类里面的配置就会生效(判断当前应用是否为web应用)
type = Type.SERVLET
)
@ConditionalOnClass({CharacterEncodingFilter.class}) // 判断当前项目有没有这个类,CharacterEncodingFilter:SpringMVC中进行乱码解决的过滤器
@ConditionalOnProperty( // 判断文件中是否存在某个配置
prefix = "spring.http.encoding",
value = {"enabled"},
matchIfMissing = true // 即使配置文件中不配置spring.http.encoding.enable=true,也是默认生效的
)
public class HttpEncodingAutoConfiguration {

根据当前不同的条件判断,决定配置类是否生效,就会通过@Bean为容器中添加各种组件,这些组件的值需要从properties中获取,properties中的每一个属性和配置文件绑定。

注意点:

  • @Conditional派生注解(来源于Spring底层注解@Conditional)

    1.作用:必须是@Conditional指定的条件成立,才给容器中添加组件,配置里面的所有内容才生效。

    2.自动配置类必须在一定的条件下才会生效:在配置文件中
	debug=true

可以在控制台打印自动配置报告,可以查看哪些自动配置生效,哪些自动配置不生效。

总结

  • SpringBoot启动会加载大量的自动配置类。
  • 判断SpringBoot默认写好的自动配置类有没有需要的功能。
  • 判断自动配置类是否配置需要的组件,没有的就需要自己配置。
  • 给容器中自动配置类添加组件时,会从properties中获取属性,在配置文件中指定这些属性的值。
  • xxAutoConfiguration:自动配置类,给容器中添加组件===xxProperties:封装配置文件中的相关属性,和配置文件绑定

微服务架构学习Day01-SpringBoot入门的更多相关文章

  1. 使用Redis为注册中心的Dubbo微服务架构(基于SpringBoot)

    title: 使用Redis为注册中心的Dubbo微服务架构(基于SpringBoot) date: 2019-07-30 14:06:29 categories: 架构 author: mrzhou ...

  2. 微服务架构学习与思考(10):微服务网关和开源 API 网关01-以 Nginx 为基础的 API 网关详细介绍

    微服务架构学习与思考(10):微服务网关和开源 API 网关01-以 Nginx 为基础的 API 网关详细介绍 一.为什么会有 API Gateway 网关 随着微服务架构的流行,很多公司把原有的单 ...

  3. 微服务架构学习与思考(11):开源 API 网关02-以 Java 为基础的 API 网关详细介绍

    微服务架构学习与思考(11):开源 API 网关02-以 Java 为基础的 API 网关详细介绍 上一篇关于网关的文章: 微服务架构学习与思考(10):微服务网关和开源 API 网关01-以 Ngi ...

  4. Spring Cloud 微服务架构学习笔记与示例

    本文示例基于Spring Boot 1.5.x实现,如对Spring Boot不熟悉,可以先学习我的这一篇:<Spring Boot 1.5.x 基础学习示例>.关于微服务基本概念不了解的 ...

  5. 基于Spring Boot和Spring Cloud实现微服务架构学习

    转载自:http://blog.csdn.net/enweitech/article/details/52582918 看了几周Spring相关框架的书籍和官方demo,是时候开始总结下这中间的学习感 ...

  6. 基于Spring Boot和Spring Cloud实现微服务架构学习--转

    原文地址:http://blog.csdn.net/enweitech/article/details/52582918 看了几周spring相关框架的书籍和官方demo,是时候开始总结下这中间的学习 ...

  7. .NET Core微服务架构学习与实践系列文章索引目录

    一.为啥要总结和收集这个系列? 今年从原来的Team里面被抽出来加入了新的Team,开始做Java微服务的开发工作,接触了Spring Boot, Spring Cloud等技术栈,对微服务这种架构有 ...

  8. 微服务架构学习与思考(09):分布式链路追踪系统-dapper论文学习

    一.技术产生的背景 1.1 背景 先来了解一下分布式链路追踪技术产生的背景. 在现在这个发达的互联网世界,互联网的规模越来越大,比如 google 的搜索,Netflix 的视频流直播,淘宝的购物等. ...

  9. SpingCloud微服务架构学习(一)之服务提供者与服务消费者

    微服务构建的是分布式系统,各个微服务之间通过网络进行服务调用,这就有了服务提供者(被调用方)和服务消费者(调用方),以电影售票系统为例,假设服务调用关系如下图所示: 围绕此场景,我们先编写一个用户微服 ...

随机推荐

  1. HTML&CSS:构建网站不能不说的那些事儿

    很高兴你能看到这个专栏!俗话说得好,相逢即是缘分,没准你和我在上一世也曾有过五百次的回眸,才得此一面.说的有点恶心了,咱还是书归正传,说说这个专栏吧. 这个专栏主要讲的是 HTML 和 CSS 的页面 ...

  2. 翻译 - ASP.NET Core 基本知识 - 中间件(Middleware)

    翻译自 https://docs.microsoft.com/en-us/aspnet/core/fundamentals/middleware/?view=aspnetcore-5.0 中间件是集成 ...

  3. 1V转5V芯片,三个元件即可组成完整的稳压方案

    1V低电压要转成5V的电压,需要1V转5V的芯片,由于1V输入,所以不需要指望能输出多大的电流,压差和1V的供电电压意味着供电电流也是无法做大的了.一般1V转5V的输出电流在0MA-100mA,一般6 ...

  4. Django-http协议

    Http协议:超文本传输协议(应用层程序).它是客户端和服务端请求和应答的标准.Http的请求响应模型:1.客户端连接到web服务器一个http客户端,与web服务器的http端口(默认是80)建立了 ...

  5. Java 给Word不同页面设置不同背景

    Word文档中,可直接通过[设计]-[页面颜色]页面颜色,通过Java代码可参考如下设置方法: 1. 设置单一颜色背景 doc.getBackground().setType(BackgroundTy ...

  6. Java 如何给Word文档添加多行文字水印

    前言 我在以往的文章中曾介绍过如何给Word文档添加文本水印和图片水印,及怎样删除文档中的水印.关于文本水印,之前那篇教程里主要指的是单行字体的水印,而在操作Word文档时,有时也会碰到需要添加多行文 ...

  7. MySQL中redo log、undo log、binlog关系以及区别

    MySQL中redo log.undo log.binlog关系以及区别 本文转载自:MySQL中的重做日志(redo log),回滚日志(undo log),以及二进制日志(binlog)的简单总结 ...

  8. Slack 的想法很好啊,很有创新,牛。

    [原]https://www.leiphone.com/news/201411/aXHUpe4ZFI2sSwpb.html 由于以往一些用于办公的应用反响平平,因此对迅速崛起的办公交流应用Slack, ...

  9. __init__ raises an exception, then __del__ will still be called

    issue 808164: socket.close() doesn't play well with __del__ - Python tracker https://bugs.python.org ...

  10. CSRF Cross-site request forgery 跨站请求伪造

    跨站请求伪造目标站---无知用户---恶意站 http://fallensnow-jack.blogspot.com/2011/08/webgoat-csrf.html https://wiki.ca ...