生命周期监听的使用和源码解析

news/2024/7/7 21:14:30

    定义SpringApplicationRunListener来监听springApplication的启动

1.通过实现springApplicationRunListener来实现监听。

2.在 META-INF/spring.factories 中配置 org.springframework.boot.SpringApplicationRunListener=自己的Listener。

在默认的springboot配置中就有给我们配置了事件监听器。

 

 配置了EvenPublishRunListener。

 自定义myListener类。

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

import java.time.Duration;

public class myListenter implements SpringApplicationRunListener {
    @Override
    public void starting(ConfigurableBootstrapContext bootstrapContext) {
        SpringApplicationRunListener.super.starting(bootstrapContext);
        System.out.println("starting");
    }

    @Override
    public void environmentPrepared(ConfigurableBootstrapContext bootstrapContext, ConfigurableEnvironment environment) {
        SpringApplicationRunListener.super.environmentPrepared(bootstrapContext, environment);
        System.out.println("environmentPrepared");
    }

    @Override
    public void contextPrepared(ConfigurableApplicationContext context) {
        SpringApplicationRunListener.super.contextPrepared(context);
        System.out.println("contextPrepared");
    }

    @Override
    public void contextLoaded(ConfigurableApplicationContext context) {
        SpringApplicationRunListener.super.contextLoaded(context);
        System.out.println("contextLoaded");
    }

    @Override
    public void started(ConfigurableApplicationContext context, Duration timeTaken) {
        SpringApplicationRunListener.super.started(context, timeTaken);
        System.out.println("started");
    }

    @Override
    public void ready(ConfigurableApplicationContext context, Duration timeTaken) {
        SpringApplicationRunListener.super.ready(context, timeTaken);
        System.out.println("ready");
    }

    @Override
    public void failed(ConfigurableApplicationContext context, Throwable exception) {
        SpringApplicationRunListener.super.failed(context, exception);
        System.out.println("failed");
    }
}

在/META-INF/spring.factories。

org.springframework.boot.SpringApplicationRunListener=com.huang.listenter.myListenter

启动测试,效果为下:

 SpringApplicationRunListener作用位置的源码分析

starting :应用开始,SpringApplication的run方法一调用,只要有了 BootstrapContext 就执行。(此时ioc容器还没有被启动)

调用位置: 

  environmentPrepared: 环境准备好(把启动参数等绑定到环境变量中),但是ioc还没有创建;【调一次】 

调用位置: 

 contextPrepared:ioc容器创建并准备好,但是sources(主配置类)没加载。并关闭引导上下文;组件都没创建  【调一次】(看参数就可以推出现在要进行ioc启动时的配置)

 调用位置(此时创建了ioc容器):

在ioc创建好并准备好后将 BootstrapContext关闭。

 contextLoaded:ioc容器加载。主配置类加载进去了。但是ioc容器还没刷新(我们的bean没创建)。

 调用位置:

 且在此方法要在刷新ioc容器(将bean配置到ioc容器中)之前。

此方法就是刷新容器。(在此过程中就会自动创建服务器类,并将其配置到ioc容器中) 

started:ioc容器刷新了(所有bean造好了),但是 runner 没调用。

调用位置: 

 ready:ioc容器刷新了(所有bean造好了),所有 runner 调用完了。

 调用位置:

 总结

重点掌握流程和各个方法的作用即可。 

 

 


http://lihuaxi.xjx100.cn/news/1251444.html

相关文章

OpenCV reshape函数

reshape函数 在opencv中,reshape函数比较有意思,它既可以改变矩阵的通道数,又可以对矩阵元素进行序列化,非常有用的一个函数。 函数原型: C: Mat Mat::reshape(int cn, int rows0) const参数比较少,但设…

JUC并发编程初学

什么是JUC进程和线程回顾Lock锁生产者和消费者8锁的线程集合类不安全CallableCountDownLatch、CyclicBarrier、Semaphore读写锁阻塞队列线程池四大函数式接口Stream流式计算分支合并异步回调JMMvolatile深入单例模式深入理解CAS原子引用可重入锁、公平锁非公平锁、自旋锁、死锁…

基于Java在线云音乐系统设计实现(源码+lw+部署文档+讲解等)

博主介绍: ✌全网粉丝30W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战 ✌ 🍅 文末获取源码联系 🍅 👇🏻 精…

【2023】Redis配置与优化

目录 源码安装redis硬件优化配置参考常用配置示例: 系统及内核优化 操作系统:centos-7.9 redis版本:6.2.12源码安装redis 在此之前先简单的安装一个Redis mkdir /app cd /app wget https://download.redis.io/releases/redis-6.2.12.tar.gz…

Log4j,IDEA文件结构与项目结构,目标文件的定义介绍

文章目录 目录 前言 一、log4j概念介绍 1.什么是log4j? 2.使用log4j的优点? 3.使用log而不用syetem.out.println? 4.常用格式: 二、IDEA文件结构介绍 1.Sources Root: 2.Test Sources Root: 3.Resource Root: 4.Test Resource Root 5.Excluded: 三、目标文件的定义 四、IDEA…

BUUCTF Unencode 1

题目描述&#xff1a; 密文&#xff1a; 89FQA9WMD<V1A<V1S83DY.#<W3$Q,2TM]解题思路&#xff1a; 1、观察密文&#xff0c;尝试Base85、Base91等编码&#xff0c;均失败。 2、结合题目&#xff0c;联想到UUencode编码&#xff0c;尝试后成功&#xff0c;得到flag。 …

使用PlotNeuralNet绘制深度学习网络图的基本操作(二)

使用PlotNeuralNet绘制深度学习网络图的基本操作&#xff08;二&#xff09; 接下来我们利用pycharm来绘制当中我们的神经网络模型架构&#xff0c;目标是直接将.tex文件生成为pdf和png。我在学习的过程中参考了一些学习视频&#xff0c;觉得这个up主讲的还不错&#xff1a; 1…

MySQL - 第2节 - MySQL库的操作

目录 1.创建数据库 2.创建数据库案例 3.字符集和校验规则 3.1.查看系统默认字符集以及校验规则 3.2.查看数据库支持的字符集 3.3.查看数据库支持的字符集校验规则 3.4.校验规则对数据库的影响 4.操纵数据库 4.1.查看数据库 4.2.显示创建语句 4.3.修改数据库 4.4.删…