当前位置: 首页 > news >正文

SpringBoot ApplicationEvent详解

ApplicationStartingEvent 阶段
LoggingApplicationListener#onApplicationStartingEvent
初始化日志工厂,LoggingSystemFactory接口,可以通过spring.factories进行定制
可以通过System.setProperty("org.springframework.boot.logging.LoggingSystem","类全路径限定名或者none") 指定log实现类
如果配置的是none,则返回 org.springframework.boot.logging.LoggingSystem.NoOpLoggingSystem
springboot默认指定了三种类型:
org.springframework.boot.logging.logback.LogbackLoggingSystem.Factory
org.springframework.boot.logging.log4j2.Log4J2LoggingSystem.Factory
org.springframework.boot.logging.java.JavaLoggingSystem.Factory
----------
BackgroundPreinitializer#onApplicationEvent 在当前阶段不做任何处理!!!
可以通过System.setProperty("spring.backgroundpreinitializer.ignore","true|false")
同时满足服务器是多核cpu并且非GraalVM环境
来指定是否通过后台线程去加载某些资源,默认是单独开一个线程来加载某些资源
线程名称:background-preinit 
后台加载的资源:
    ConversionServiceInitializer.class 
    ValidationInitializer.class 
    MessageConverterInitializer.class 
    JacksonInitializer.class 
    CharsetInitializer.class
有异常直接忽略
----------
DelegatingApplicationListener#onApplicationEvent 在当前阶段不做任何处理!!!
可以通过配置 context.listener.classes 属性来指定要执行的listener,是一个复合包装类
内部定义了SimpleApplicationEventMulticaster事件驱动类,用来指定配置的listener
==========
ApplicationEnvironmentPreparedEvent 阶段
EnvironmentPostProcessorApplicationListener#onApplicationEvent
onApplicationEnvironmentPreparedEvent((ApplicationEnvironmentPreparedEvent) event);
获取ConfigurableEnvironment实例
获取SpringApplication实例
通过SpringApplication实例.getResourceLoader()和ConfigurableEnvironment实例.getBootstrapContext() 获取 EnvironmentPostProcessors
所有实现了 org.springframework.boot.env.EnvironmentPostProcessor 接口的实现类,同样可以通过 spring.factories进行定制
开始遍历
1、RandomValuePropertySourceEnvironmentPostProcessor#postProcessEnvironment
将RandomValuePropertySource添加到systemEnvironment这个属性解析器集合的最后一位
RandomValuePropertySource: 用法,配置属性以random开头
比如:random.int 返回正负32位以内的一个伪随机数字
random.long 返回正负64位以内的一个伪随机数字
random.int(0,9) 包含0不包含9 中的一个伪随机数字
random.long[0,9] 包含0不包含9 中的一个伪随机数字
() 和 [] 或者 $$ 作用都一样 前后任意两个字符括起来,数字使用逗号分隔即可
2、SystemEnvironmentPropertySourceEnvironmentPostProcessor#postProcessEnvironment
判断是否设置了 SpringApplication.environmentPrefix 属性,如果设置了将systemEnvironment(SystemEnvironmentPropertySource)
的数据封装为OriginAwareSystemEnvironmentPropertySource类(SystemEnvironmentPropertySource的子类),有prefix属性.
spring.main.environment-prefix:不允许这样设置
可以通过 SpringApplicationBuilder.environmentPrefix("xx") 来设置,可以以 . - _ 等结尾,
3、SpringApplicationJsonEnvironmentPostProcessor#postProcessEnvironment
解析json属性,使用spring.application.json或者SPRING_APPLICATION_JSON命令行参数指定,按序返回有效的第一个进行解析.
解析成功后,将json属性封装为JsonPropertySource,放到servlet sources前面,如果不是servlet环境,则放在第一位
解析json属性的解析器:
org.springframework.boot.json.JsonParserFactory#getJsonParser: 指定了4种json解析器
com.fasterxml.jackson.databind.ObjectMapper
com.google.gson.Gson
org.yaml.snakeyaml.Yaml
org.springframework.boot.json.BasicJsonParser
按以上顺序进行加载,加载成功就返回对应的对象实例
4、CloudFoundryVcapEnvironmentPostProcessor#postProcessEnvironment 在springcloud环境下生效
判断是否设置了 spring.main.cloud-platform VCAP_APPLICATION VCAP_SERVICES 满足任意一个
设置了 添加 vcap sources
5、ConfigDataEnvironmentPostProcessor#postProcessEnvironment **你个**   加载并且解析设定的配置文件
spring.config.on-not-found: 配置找不到的处理方法,参考ConfigDataNotFoundAction枚举类
SpringApplication.additionalProfiles 通过 builder 构建
加载指定的配置文件并且设置environment中的profiles
# ConfigData Location Resolvers
org.springframework.boot.context.config.ConfigDataLocationResolver=\
org.springframework.boot.context.config.ConfigTreeConfigDataLocationResolver,\
org.springframework.boot.context.config.StandardConfigDataLocationResolver

# ConfigData Loaders
org.springframework.boot.context.config.ConfigDataLoader=\
org.springframework.boot.context.config.ConfigTreeConfigDataLoader,\
org.springframework.boot.context.config.StandardConfigDataLoader
6、DebugAgentEnvironmentPostProcessor#postProcessEnvironment
reactor.tools.agent.ReactorDebugAgent有这个类并且spring.reactor.debug-agent.enabled属性配置为true时
执行 ReactorDebugAgent init() 方法
7、IntegrationPropertiesEnvironmentPostProcessor#postProcessEnvironment
META-INF/spring.integration.properties 这个文件存在时加载内容并且转化为IntegrationPropertiesPropertySource添加到sources结尾
----------
AnsiOutputApplicationListener#onApplicationEvent
进行属性绑定 spring.output.ansi.enabled org.springframework.boot.ansi.AnsiOutput#enabled 参考 Enabled 枚举类
spring.output.ansi.console-available  AnsiOutput.consoleAvailable = consoleAvailable
----------
LoggingApplicationListener#onApplicationEvent
日志文件和属性初始化配置
----------
BackgroundPreinitializer#onApplicationEvent
可以通过System.setProperty("spring.backgroundpreinitializer.ignore","true|false")
同时满足服务器是多核cpu并且非GraalVM环境
来指定是否通过后台线程去加载某些资源,默认是单独开一个线程来加载某些资源
线程名称:background-preinit 
后台加载的资源:
    ConversionServiceInitializer.class 
    ValidationInitializer.class 
    MessageConverterInitializer.class 
    JacksonInitializer.class 
    CharsetInitializer.class
有异常直接忽略
----------
DelegatingApplicationListener#onApplicationEvent
可以通过配置 context.listener.classes 属性来指定要执行的listener,是一个复合包装类
内部定义了SimpleApplicationEventMulticaster事件驱动类,用来指定配置的listener
----------
FileEncodingApplicationListener#onApplicationEvent1
spring.mandatory-file-encoding: 查看是否配置了此属性,强制编码,如果这个与file.encoding不符合报错!!!
==========
bindToSpringApplication(environment) // 将spring.main开头的属性配置绑定到SpringApplication属性上
==========
applyInitializers(context); // 执行ApplicationContextInitializer接口的实现类
==========
ApplicationContextInitializedEvent
BackgroundPreinitializer#onApplicationEvent 此阶段啥也不做!!!
----------
DelegatingApplicationListener#onApplicationEvent 此阶段啥也不做!!!
==========
ApplicationPreparedEvent
EnvironmentPostProcessorApplicationListener#onApplicationEvent
onApplicationPreparedEvent() > EnvironmentPostProcessorApplicationListener#finish() > DeferredLogs#switchOverAll()
打印日志 
----------
LoggingApplicationListener#onApplicationEvent
注册springBootLoggingSystem单例Bean
logFile存在并且springBootLogFile不存在这个Bean时注册springBootLogFile单例Bean
loggerGroups存在并且springBootLoggerGroups不存在这个Bean时注册springBootLoggerGroups单例Bean
springBootLoggingLifecycle单例Bean不存在BeanFactory.getParent为空时注册springBootLoggingLifecycle单例Bean
----------
BackgroundPreinitializer#onApplicationEvent 此阶段啥也不做!!!
----------
DelegatingApplicationListener#onApplicationEvent 此阶段啥也不做!!!
==========
中间存在的各种事件驱动类
ServletWebServerInitializedEvent
SpringApplicationAdminMXBeanRegistrar#onApplicationEvent : onWebServerInitializedEvent((WebServerInitializedEvent) event);
DelegatingApplicationListener#onApplicationEvent 此阶段啥也不做!!!
ServerPortInfoApplicationContextInitializer#onApplicationEvent : 绑定server.ports sources
----------
ContextRefreshedEvent
DelegatingApplicationListener#onApplicationEvent 此阶段啥也不做!!!
ConditionEvaluationReportLoggingListener.ConditionEvaluationReportListener#onApplicationEvent 打印方法 ConditionEvaluationReportMessage
ClearCachesApplicationListener#onApplicationEvent 清理加载反射field和method的缓存数据,调用类加载器的clearCache方法清理缓存
SharedMetadataReaderFactoryContextInitializer.SharedMetadataReaderFactoryBean#onApplicationEvent 清理加载的class缓存数据
ResourceUrlProvider#onApplicationEvent 静态资源 /webjars/** 和 /static/**
==========
ApplicationStartedEvent
BackgroundPreinitializer#onApplicationEvent 此阶段啥也不做!!!
----------
DelegatingApplicationListener#onApplicationEvent 此阶段啥也不做!!!
----------
StartupTimeMetricsListener#onApplicationEvent
设置埋点监控 TimeGauge
----------
TomcatMetricsBinder#onApplicationEvent
设置tomcat监控绑定
----------
AvailabilityChangeEvent
DelegatingApplicationListener#onApplicationEvent 此阶段啥也不做!!!
----------
ApplicationAvailabilityBean#onApplicationEvent 添加到 org.springframework.boot.availability.ApplicationAvailabilityBean#events 集合中 应用启动好了
==========
ApplicationReadyEvent
SpringApplicationAdminMXBeanRegistrar#onApplicationEvent 应用准备好了
----------
BackgroundPreinitializer#onApplicationEvent 此阶段啥也不做!!!
----------
StartupTimeMetricsListener#onApplicationEvent  注册TimeGauge埋点监控
----------
DelegatingApplicationListener#onApplicationEvent 此阶段啥也不做!!!
==========
AvailabilityChangeEvent
ApplicationAvailabilityBean#onApplicationEvent 添加到 org.springframework.boot.availability.ApplicationAvailabilityBean#events 集合中 应用准备好了
 

相关文章:

SpringBoot ApplicationEvent详解

ApplicationStartingEvent 阶段 LoggingApplicationListener#onApplicationStartingEvent 初始化日志工厂,LoggingSystemFactory接口,可以通过spring.factories进行定制 可以通过System.setProperty("org.springframework.boot.logging.LoggingSystem",&q…...

WebSocket 报java.io.IOException: 远程主机强迫关闭了一个现有的连接。

在客户端强制关闭时,或者窗口强制关闭时,后端session没有关闭。 有时还会报:java.io.EOFException: 这个异常 前端心跳没有收到信息,还在心跳。 CloseReason close new CloseReason(CloseReason.CloseCodes.NORMAL_CLOSURE, &…...

关于git约定式提交IDEA

背景 因为git提交的消息不规范导致被乱喷,所以领导统一规定了约定式提交 官话 约定式提交官网地址 约定式提交规范是一种基于提交信息的轻量级约定。 它提供了一组简单规则来创建清晰的提交历史; 这更有利于编写自动化工具。 通过在提交信息中描述功能…...

【计算机网络】http协议

目录 前言 认识URL URLEncode和URLDecode http协议格式 http方法 GET POST GET与POST的区别 http状态码 http常见header 简易的http服务器 前言 我们在序列化和反序列化这一章中,实现了一个网络版的计算器。这个里面设计到了对协议的分析与处…...

仓库太大,clone 后,git pull 老分支成功,最新分支失败

由于 git 仓库太大,新加入的小伙伴在拉取时,无法切换到最新的分支,报错如下: fetch-pack: unexpected disconnect while reading sideband packet fatal: early EOF fatal: fetch-pack: invalid index-pack output在此记录解决步…...

javafx Dialog无法关闭

// 生成二维码图片String qrCodeText "https://example.com";DialogPane grid new DialogPane();grid.setPadding(new Insets(5));VBox vBox new VBox();vBox.setAlignment(Pos.CENTER);Image qrCodeImage generateQRCodeImage(qrCodeText);ImageView customImag…...

vue3中TCplayer应用

环境win10:vitevue3elementUI 1 安装 npm install tcplayer.js2 使用 <template><div><video id"player-container-id" width"414" height"270" preload"auto" playsinline webkit-playsinline></video>&l…...

算法通关村14关 | 数据流中位数问题

1. 数据流中位数问题 题目 LeetCode295: 中位数是有序列表中间的数&#xff0c;如果列表长度是偶数&#xff0c;中位数是中间两个数的平均值&#xff0c; 例如:[2,3,4]的中位数是3&#xff0c; [2,3]中位数是&#xff08;23&#xff09;/ 2 2.5 设计一个数据结构&#xff1a; …...

工厂模式 与 抽象工厂模式 的区别

工厂模式&#xff1a; // 抽象产品接口 interface Product {void showInfo(); }// 具体产品A class ConcreteProductA implements Product {Overridepublic void showInfo() {System.out.println("This is Product A");} }// 具体产品B class ConcreteProductB impl…...

安装虚拟机+安装/删除镜像

安装虚拟机 注意&#xff0c;官网可能无法登录&#xff0c;导致无法从官网下载&#xff0c;就自己去网上搜靠谱的下载&#xff0c;我用的16.2.3 删除镜像 Vm虚拟机怎么删除已经创建的系统&#xff1f;Vm虚拟机创建好之后iso删除方法 - 系统之家 (xitongzhijia.net) 安装镜像…...

MySQL的内置函数复合查询内外连接

文章目录 内置函数时间函数字符串函数数学函数其他函数 复合查询多表笛卡尔积自连接在where中使用子查询多列子查询在from中使用子查询 内连接外连接左外连接右外连接 内置函数 时间函数 函数描述current_date()当前日期current_time()当前时间current_timestamp()当前时间戳…...

操作系统(OS)与系统进程

操作系统&#xff08;OS&#xff09;与系统进程 冯诺依曼体系结构操作系统(Operator System)进程基本概念进程的描述&#xff08;PCB&#xff09;查看进程通过系统调用获取进程标示符&#xff08;PID&#xff09;通过系统调用创建进程&#xff08;fork&#xff09;进程状态&…...

防重复提交:自定义注解 + 拦截器(HandlerInterceptor)

防重复提交&#xff1a;自定义注解 拦截器&#xff08;HandlerInterceptor&#xff09; 一、思路&#xff1a; 1、首先自定义注解&#xff1b; 2、创建拦截器实现类&#xff08;自定义类名称&#xff09;&#xff0c;拦截器&#xff08;HandlerInterceptor&#xff09;; 3…...

Excel中将文本格式的数值转换为数字

在使用excel时&#xff0c;有时需要对数字列进行各种计算&#xff0c;比如求平均值&#xff0c;我们都知道应该使用AVERAGE()函数&#xff0c;但是很多时候结果却“不尽如人意”。 1 问题&#xff1a; 使用AVERAGE函数&#xff1a; 结果&#xff1a; 可以看到单元格左上角有个…...

uni-app开发小程序中遇到的map地图的点聚合以及polygon划分区域问题

写一篇文章来记录以下我在开发小程序地图过程中遇到的两个小坑吧&#xff0c;一个是点聚合&#xff0c;用的是joinCluster这个指令&#xff0c;另一个是polygon在地图上划分多边形的问题&#xff1a; 1.首先说一下点聚合问题&#xff0c;由于之前没有做过小程序地图问题&#…...

【笔记】软件测试的艺术

软件测试的心理学和经济学 测试是为发现错误而执行程序的过程&#xff0c;所以它是一个破坏性的过程&#xff0c;测试是一个“施虐”的过程。 软件测试的10大原则 1、测试用例需要对预期输出的结果有明确的定义 做这件事的前提是能够提前知晓需求和效果图&#xff0c;如果不…...

配置本地maven

安装maven安装包 修改环境变量 vim ~/.bash_profile export JMETER_HOME/Users/yyyyjinying/apache-jmeter-5.4.1 export GOROOT/usr/local/go export GOPATH/Users/yyyyjinying/demo-file/git/backend/go export GROOVY_HOME/Users/yyyyjinying/sortware/groovy-4.0.14 exp…...

C# 按钮的AcceptButton和CancelButton属性

using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System...

SMT贴片制造:专业、现代、智能的未来之选

在现代科技的快速发展下&#xff0c;SMT贴片制造作为电子元器件的核心工艺之一&#xff0c;正以其专业、现代和智能的特点成为未来的首选。 随着电子产品越来越小型化&#xff0c;传统的手工焊接已经无法满足高速、高精度、高稳定性的要求。而SMT贴片制造作为一种先进的表面贴…...

python sqlalchemy db.session 的commit()和colse()对session中的对象的影响

实验一&#xff1a;commit&#xff08;&#xff09;之后查看stu的属性id,查看db.session是否改变 db_test.route("/db_test",methods["GET"]) def db_test():stuStuTest()stu.stu_age22stu.stu_name"nnannns"stu.stu_class11print("sessio…...

【OSG学习笔记】Day 18: 碰撞检测与物理交互

物理引擎&#xff08;Physics Engine&#xff09; 物理引擎 是一种通过计算机模拟物理规律&#xff08;如力学、碰撞、重力、流体动力学等&#xff09;的软件工具或库。 它的核心目标是在虚拟环境中逼真地模拟物体的运动和交互&#xff0c;广泛应用于 游戏开发、动画制作、虚…...

Qt Http Server模块功能及架构

Qt Http Server 是 Qt 6.0 中引入的一个新模块&#xff0c;它提供了一个轻量级的 HTTP 服务器实现&#xff0c;主要用于构建基于 HTTP 的应用程序和服务。 功能介绍&#xff1a; 主要功能 HTTP服务器功能&#xff1a; 支持 HTTP/1.1 协议 简单的请求/响应处理模型 支持 GET…...

Springcloud:Eureka 高可用集群搭建实战(服务注册与发现的底层原理与避坑指南)

引言&#xff1a;为什么 Eureka 依然是存量系统的核心&#xff1f; 尽管 Nacos 等新注册中心崛起&#xff0c;但金融、电力等保守行业仍有大量系统运行在 Eureka 上。理解其高可用设计与自我保护机制&#xff0c;是保障分布式系统稳定的必修课。本文将手把手带你搭建生产级 Eur…...

LLM基础1_语言模型如何处理文本

基于GitHub项目&#xff1a;https://github.com/datawhalechina/llms-from-scratch-cn 工具介绍 tiktoken&#xff1a;OpenAI开发的专业"分词器" torch&#xff1a;Facebook开发的强力计算引擎&#xff0c;相当于超级计算器 理解词嵌入&#xff1a;给词语画"…...

《基于Apache Flink的流处理》笔记

思维导图 1-3 章 4-7章 8-11 章 参考资料 源码&#xff1a; https://github.com/streaming-with-flink 博客 https://flink.apache.org/bloghttps://www.ververica.com/blog 聚会及会议 https://flink-forward.orghttps://www.meetup.com/topics/apache-flink https://n…...

【学习笔记】深入理解Java虚拟机学习笔记——第4章 虚拟机性能监控,故障处理工具

第2章 虚拟机性能监控&#xff0c;故障处理工具 4.1 概述 略 4.2 基础故障处理工具 4.2.1 jps:虚拟机进程状况工具 命令&#xff1a;jps [options] [hostid] 功能&#xff1a;本地虚拟机进程显示进程ID&#xff08;与ps相同&#xff09;&#xff0c;可同时显示主类&#x…...

ip子接口配置及删除

配置永久生效的子接口&#xff0c;2个IP 都可以登录你这一台服务器。重启不失效。 永久的 [应用] vi /etc/sysconfig/network-scripts/ifcfg-eth0修改文件内内容 TYPE"Ethernet" BOOTPROTO"none" NAME"eth0" DEVICE"eth0" ONBOOT&q…...

【7色560页】职场可视化逻辑图高级数据分析PPT模版

7种色调职场工作汇报PPT&#xff0c;橙蓝、黑红、红蓝、蓝橙灰、浅蓝、浅绿、深蓝七种色调模版 【7色560页】职场可视化逻辑图高级数据分析PPT模版&#xff1a;职场可视化逻辑图分析PPT模版https://pan.quark.cn/s/78aeabbd92d1...

免费数学几何作图web平台

光锐软件免费数学工具&#xff0c;maths,数学制图&#xff0c;数学作图&#xff0c;几何作图&#xff0c;几何&#xff0c;AR开发,AR教育,增强现实,软件公司,XR,MR,VR,虚拟仿真,虚拟现实,混合现实,教育科技产品,职业模拟培训,高保真VR场景,结构互动课件,元宇宙http://xaglare.c…...

【MATLAB代码】基于最大相关熵准则(MCC)的三维鲁棒卡尔曼滤波算法(MCC-KF),附源代码|订阅专栏后可直接查看

文章所述的代码实现了基于最大相关熵准则(MCC)的三维鲁棒卡尔曼滤波算法(MCC-KF),针对传感器观测数据中存在的脉冲型异常噪声问题,通过非线性加权机制提升滤波器的抗干扰能力。代码通过对比传统KF与MCC-KF在含异常值场景下的表现,验证了后者在状态估计鲁棒性方面的显著优…...