SmartLifecycle和Lifecycle的作用和区别

本文基于SpringBoot 2.5.0-M2讲解Spring中Lifecycle和SmartLifecycle的作用和区别,以及如何控制SmartLifecycle的优先级。

并讲解SpringBoot中如何通过SmartLifecycle来启动/停止web容器.

SmartLifecycle & Lifecycle作用和区别

SmartLifecycle和Lifecycle作用

都是让开发者可以在所有的bean都创建完成(getBean) 之后执行自己的初始化工作,或者在退出时执行资源销毁工作。

SmartLifecycle和Lifecycle区别

在SpringBoot应用中,或在Spring应用中没有调用

AbstractApplicationContext#start方法,如果一个Bean只是实现了Lifecycle接口的情况下:

不会执行Lifecycle接口中的启动方法,包括Lifecycle#isRunning方法也不会被执行。

但是在应用 退出时 会执行Lifecycle#isRunning方法判断该Lifecycle是否已经启动,如果返回true则调用Lifecycle#stop()停止方法。

如果一个Bean实现了SmartLifecycle接口,则会执行启动方法。先会被根据Phased接口优先级分组,封装在LifecycleGroup,然后循环调用LifecycleGroup#start()方法,SmartLifecycle#isRunning判断是否已经执行,返回false表示还未执行,则调用SmartLifecycle#start()执行。Phased返回值越小,优先级越高。

SmartLifecycle中还有个isAutoStartup方法,如果返回false,在启动时也不会执行start方法,默认返回true

源码分析

DefaultLifecycleProcessor#onRefresh方法在执行

AbstractApplicationContext#finishRefresh时会被调用,调用栈如下:

DefaultLifecycleProcessor#onRefresh源码:

DefaultLifecycleProcessor#startBeans源码如下:

autoStartupOnly 在onRefresh时传入的是true,表示只执行可以自动启动的bean,即为:SmartLifecycle的实现类,并且SmartLifecycle#isAutoStartup返回值必须为true。

而Spring

AbstractApplicationContext#doClose退出时,无论是SmartLifecycle或Lifecycle都会执行isRunning方法,判断是否已经启动,返回true表示已经启动,则执行SmartLifecycle或Lifecycle的stop方法。

而执行

AbstractApplicationContext#doClose一般是应用进程退出,通过jvm注册的钩子方法,或者应用程序编码调用。

AbstractApplicationContext#registerShutdownHook源码

自定义LifecycleProcessor处理Lifecycle

在源码分析中提到了DefaultLifecycleProcessor,其实现了LifecycleProcessor接口。然而我们自己也可以实现该接口,替换默认的DefaultLifecycleProcessor。SpringBoot中则是自己配置了DefaultLifecycleProcessor,我们可以按照同样的方式,覆盖默认的实现。例如可以让Lifecycle中的start()方法在onRefresh()时也能被执行。

SpringBoot中内嵌web容器启动时机

SpringBoo中就是通过实现SmartLifecycle来启动内嵌的web容器,实现类为

WebServerStartStopLifecycle。

ServletWebServerApplicationContext在onRefresh方法中调用createWebServer,createWebServer方法中创建org.springframework.boot.web.server.WebServer实例,该对象则包含了控制web容器(tomcat、jetty)的启动与停止方法。

ServletWebServerApplicationContext#createWebServer源码:

createWebServer方法会将创建的webServer封装在

WebServerStartStopLifecycle对象中,并注册到Spring容器中。

WebServerStartStopLifecycle则实现了SmartLifecycle接口,当Spring回调到SmartLifecycle接口方法时则调用this.webServer.start();启动web容器,web容器启动完成之后会通过applicationContext发布ServletWebServerInitializedEvent事件,表示web容器启动成功,可以接收http请求。

SmartInitializingSingleton区别

相同点:

SmartInitializingSingleton和Lifecycle、SmartLifecycle都是在所有的单实例bean创建(getBean方法)之后执行。

不同点:

SmartInitializingSingleton优先于Lifecycle、SmartLifecycle执行。

SmartInitializingSingleton只有一个afterSingletonsInstantiated方法。而Lifecycle有start,stop,isRunning等方法。

多个

SmartInitializingSingleton实现之间无法排序控制执行的顺序,而SmartLifecycle实现了Phased接口,可以通过int getPhase()控制执行循序。

SmartInitializingSingleton之间可以通过@DependsOn来控制执行顺序,但这是由Spring中@DependsOn注解的作用及原理来实现的. 并不是对SmartInitializingSingleton做了排序。

————————————————

版权声明:本文为CSDN博主「brucelwl」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

(0)

相关推荐

  • 干货:Java报错收集整理

    在学习Java和算法过程中,需要使用Java的编译和执行命令.但是有时总是会出现各种报错,今天开课吧广场小编整理了开课吧教研老师提供的文章,希望能为遇到此问题的小伙伴帮助发现错误原因,找到对应方法解决 ...

  • jenkins显示html样式问题的几种解决方案

    前言 jenkins上使用HTML Publisher plugin插件生成的html报告样式会丢失,需要设置下才能正常显示. 一.样式丢失 1.官方文档的解释如下,参考地址https://stack ...

  • 买手店加咖啡店的完美融合--LifeCycle

    买手店加咖啡店的完美融合--LifeCycle

  • 如何利用Flutter实现好友列表(内涵源码)

    早前的<HelloWorld>公开课,资深大前端开发工程师阿佑老师为我们详细介绍了如何利用Flutter做界面开发.学员们反馈意犹未尽,问还没有关于Flutter的公开课.4月24日,阿佑 ...

  • SpringBoot启动流程总结

    一直很好奇SpringBoot这么一个大怪物,启动的时候做了哪些事情,然后看了很多老师讲的教学视频,然后自己想好好整理一下,做下学习笔记下次也方便自己阅读 1.执行main方法 public stat ...

  • 氨基酸、黄腐酸、腐植酸:三大生物刺激剂的作用与区别

    在农化产品分支中,有一个古老而新颖的品类--生物刺激剂. 根据欧洲生物刺激剂行业委员会(EBIC)的定义:内含某些成分和(或)微生物的物质,当施用于作物或其根际周围时,能够促进作物的自然生理代谢,增强 ...

  • 高压隔离开关、断路器、负荷开关的作用与区别!图文详解,收藏吧

    导 读: 负荷开关.隔离开关.断路器都在一次回路中承载回路额定电流.简而言之呢,断路器是用来保护电路的,负荷开关可以断开和接通系统正常的负载电流,隔离开关的作用也不容忽视,隔离开关在电路中起到明显断开 ...

  • 保护接零与保护接地的作用和区别

    什么是接零保护,什么是接地保护,虽然头条号里面有很多这方面的知识,但是估计一般人员还是很少了解并关注到这一块,但是他又涉及到安全方面,所以今天又拿出来特地总结了一下,推荐大家来了解一下,这也算是电工类 ...

  • 负荷开关、隔离开关、断路器具体的作用与区别

    导 读 负荷开关.隔离开关.断路器都在一次回路中承载回路额定电流.简而言之呢,断路器是用来保护电路的,负荷开关可以断开和接通系统正常的负载电流,隔离开关的作用也不容忽视,隔离开关在电路中起到明显断开点 ...

  • 储液干燥器和集液器的作用和区别

    储液干燥器和集液器的作用和区别 06-18 a)储液干燥器  储液干燥器用于膨胀阀式的制冷循环,其作用是: ① 暂时存储制冷剂,使制冷剂的流量与制冷负荷相适应: ② 去除制冷剂中的水分和杂质,确保系统 ...

  • 太阳能控制器的作用和区别

    太阳能控制器全称为太阳能充放电控制器,是用于太阳能发电系统中,控制多路太阳能电池方阵对蓄电池充电以及蓄电池给太阳能逆变器负载供电的自动控制设备.它对蓄电池的充.放电条件加以规定和控制,并按照负载的电源 ...

  • Excel计数函数:COUNT 、COUNTIF、COUNTIFS的作用与区别

    Excel的基础函数中求和函数是最为人熟知,也是最常用函数之一,SUM.SUMIF.SUMIFS都是求和函数,今天我们不讲求和函数,今天说的是计数函数,在名字结构上很像求和函数,它们分别是COUNT ...

  • 施工图预算和施工预算的作用及区别?

    从事建筑行业的人员都了解,作为工程项目成本的重要组成部分之一,施工图预算是帮助管理者确定和控制项目成本的重要手段,下来就由西北国际招标代理小编带大家来了解一下吧. 一.施工图预算主要作用: (1)是考 ...

  • 拉电阻详解: 上拉电阻与下拉电阻的作用及区别

    上拉(Pull Up )或下拉(Pull Down)电阻(两者统称为"拉电阻"),电阻在电路中起限制电流的作用,而上拉电阻和下拉电阻是经常提到也是经常用到的电阻.对于某些集成电路或 ...