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

SpringBoot事件机制

SpringBoot事件机制

启动入口

SpringApplication.run(H2Application.class, args);方法

public ConfigurableApplicationContext run(String... args) {
		StopWatch stopWatch = new StopWatch();
		stopWatch.start();
		DefaultBootstrapContext bootstrapContext = createBootstrapContext();
		ConfigurableApplicationContext context = null;
		configureHeadlessProperty();
		SpringApplicationRunListeners listeners = getRunListeners(args);
    	//1.发送ApplicationStartingEvent事件,回调starting
		listeners.starting(bootstrapContext, this.mainApplicationClass);
		try {
			ApplicationArguments applicationArguments = new DefaultApplicationArguments(args);
            //2.发送ApplicationEnvironmentPreparedEvent事件,回调environmentPrepared,
            //listeners.environmentPrepared(bootstrapContext, environment);
			ConfigurableEnvironment environment = prepareEnvironment(listeners, bootstrapContext, applicationArguments);
			configureIgnoreBeanInfo(environment);
			Banner printedBanner = printBanner(environment);
			context = createApplicationContext();
			context.setApplicationStartup(this.applicationStartup);
            //3.listeners.contextPrepared(context);
            //4.listeners.contextLoaded(context);
			prepareContext(bootstrapContext, context, environment, listeners, applicationArguments, printedBanner);
			refreshContext(context);
			afterRefresh(context, applicationArguments);
			stopWatch.stop();
			if (this.logStartupInfo) {
				new StartupInfoLogger(this.mainApplicationClass).logStarted(getApplicationLog(), stopWatch);
			}
            //5.ApplicationStartedEvent事件 listeners.started(context);
			listeners.started(context);
			callRunners(context, applicationArguments);
		}
		catch (Throwable ex) {
            //ApplicationFailedEvent
			handleRunFailure(context, ex, listeners);
			throw new IllegalStateException(ex);
		}

		try {
            //6.ApplicationReadyEvent事件 listeners.running(context);
			listeners.running(context);
		}
		catch (Throwable ex) {
			handleRunFailure(context, ex, null);
			throw new IllegalStateException(ex);
		}
		return context;
	}

事件整理

事件含义:

事件名称回调方法含义主要动作
ApplicationStartingEventstartingSpirng应用开始了
ApplicationEnvironmentPreparedEventenvironmentPrepared应用环境变量配置完成
ApplicationContextInitializedEventcontextPrepared准备ApplicationContext
ApplicationPreparedEventcontextLoaded完成ApplicationContext
ApplicationStartedEventstartedSpring应用启动结束;执行ApplicationRunner和CommandLineRunner
ApplicationReadyEventrunningSpring应用正式启动完成
ApplicationFailedEventfailedSpring应用启动失败

自定义事件

复用SpringBoot内置事件机制,自定义,参考:context.publishEvent(new ExitCodeEvent(context, exitCode));

定阅事件

@Component
public class UserRegisterSendSMSListener implements ApplicationListener<UserRegisterEvent> {
 
    private static final Logger LOGGER = LoggerFactory.getLogger(UserRegisterSendSMSListener.class);
 
    @Override
    public void onApplicationEvent(UserRegisterEvent userRegisterEvent) {
        // 发送短信
        LOGGER.info("新注册用户 {} 短信发送成功", userRegisterEvent.getUser().getUserName());
    }
}

发布事件

@RestController
@RequestMapping("user")
public class UserController {
 
    @Autowired
    private ApplicationEventPublisher applicationEventPublisher;
 
    @PostMapping
    public String register(@RequestBody UserModel model) {
        // 验证
        // 注册
        // 事件
        UserRegisterEvent userRegisterEvent = new UserRegisterEvent(this, model);
        applicationEventPublisher.publishEvent(userRegisterEvent);
        return Boolean.TRUE.toString();
    }
}

自定义监听

package com.dxz.controller;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.SpringApplicationRunListener;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.core.env.ConfigurableEnvironment;

public class SampleSpringApplicationRunListener implements SpringApplicationRunListener {
    private final SpringApplication application;
    private final String[] args;
	
    //任何一个SpringApplicationRunListener实现类的构造方法都需要有两个构造参数,一个参数的类型就是我们的org.springframework.boot.SpringApplication,另外一个参数就是args参数列表的String[]
    public SampleSpringApplicationRunListener(SpringApplication sa, String[] args) {
        this.application = sa;
        this.args = args;
    }

    @Override
    public void starting() {
        System.out.println("自定义starting");
    }

    @Override
    public void environmentPrepared(ConfigurableEnvironment environment) {
        System.out.println("自定义environmentPrepared");
    }

    @Override
    public void contextPrepared(ConfigurableApplicationContext context) {
        System.out.println("自定义contextPrepared");
    }

    @Override
    public void contextLoaded(ConfigurableApplicationContext context) {
        System.out.println("自定义contextLoaded");
    }

    @Override
    public void finished(ConfigurableApplicationContext context, Throwable exception) {
        System.out.println("自定义finished");
    }
}
org.springframework.boot.SpringApplicationRunListener=\
    com.dxz.SampleSpringApplicationRunListener

相关文章:

  • IDEA配置tomcat以及创建项目
  • Node.js | 使用内置模块 event 实现发布订阅模式
  • 七千字详解javaString类
  • 希尔排序算法
  • synchronized同步以及双重检索
  • Codeforce8.29-9.4做题笔记
  • springboot+宴会预定平台 毕业设计-附源码231718
  • python super()详解,一篇文章告诉你python的super是什么,如何使用
  • Redis 的持久化
  • 2022年中国证券行业智能投顾专题分析
  • MYSQL高可用架构之MHA实战(真实可用)
  • 【Reinforcement Learning】蒙特卡洛算法
  • SAP ABAP ADT安装说明 as 20220901
  • 计算机组成原理知识总结(八)输入/输出系统
  • springboot基于java的康泰小区物业管理系统的设计与实现毕业设计源码101926
  • es6(二):字符串的扩展
  • golang中接口赋值与方法集
  • If…else
  • Java 多线程编程之:notify 和 wait 用法
  • Linux学习笔记6-使用fdisk进行磁盘管理
  • Nodejs和JavaWeb协助开发
  • SpringCloud(第 039 篇)链接Mysql数据库,通过JpaRepository编写数据库访问
  • Travix是如何部署应用程序到Kubernetes上的
  • underscore源码剖析之整体架构
  • VuePress 静态网站生成
  • vue的全局变量和全局拦截请求器
  • Webpack入门之遇到的那些坑,系列示例Demo
  • -- 查询加强-- 使用如何where子句进行筛选,% _ like的使用
  • 干货 | 以太坊Mist负责人教你建立无服务器应用
  • ------- 计算机网络基础
  • 检测对象或数组
  • 软件开发学习的5大技巧,你知道吗?
  • 十年未变!安全,谁之责?(下)
  • 温故知新之javascript面向对象
  • 译自由幺半群
  • MPAndroidChart 教程:Y轴 YAxis
  • ​【C语言】长篇详解,字符系列篇3-----strstr,strtok,strerror字符串函数的使用【图文详解​】
  • #Linux(帮助手册)
  • (k8s中)docker netty OOM问题记录
  • (LeetCode) T14. Longest Common Prefix
  • (超简单)构建高可用网络应用:使用Nginx进行负载均衡与健康检查
  • (附源码)ssm跨平台教学系统 毕业设计 280843
  • (附源码)计算机毕业设计SSM基于健身房管理系统
  • (转)socket Aio demo
  • .gitattributes 文件
  • .Net - 类的介绍
  • .NET Core中Emit的使用
  • .net php 通信,flash与asp/php/asp.net通信的方法
  • .net通用权限框架B/S (三)--MODEL层(2)
  • @ComponentScan比较
  • [ 渗透测试面试篇 ] 渗透测试面试题大集合(详解)(十)RCE (远程代码/命令执行漏洞)相关面试题
  • [.net] 如何在mail的加入正文显示图片
  • []sim300 GPRS数据收发程序
  • [1] 平面(Plane)图形的生成算法
  • [BZOJ4566][HAOI2016]找相同字符(SAM)