spring --refresh流程

spring refresh概述:

     refresh 是 AbstractApplicationContext 中的一个方法,负责初始化 ApplicationContext 容器。容器必须调用refresh才能正常工作。它的内部主要会调用12个方法,我们把它们称为refresh的12个步骤。

 

  1. prepareRefresh - 做好准备工作

  2. obtainFreshBeanFactory - 创建或获取BeanFactory

  3. prepareBeanFactory - 准备BeanFactory

  4. postProcessBeanFactory - 子类扩展BeanFactory

  5. invokeBeanFactoryPostProcessors - 后处理器扩展BeanFactory

  6. registerBeanPostProcessors - 准备Bean后处理器

  7. initMessageSource - 为ApplicationContext提供国际化功能

  8. initApplicationEventMulticaster - 为ApplicationContext提供事件发布器

  9. onRefresh - 留给子类扩展

  10. registerListeners - 为ApplicationContext准备监听器

  11. finishBeanFactoryInitialization - 实例化单例bean,执行bean后处理器扩展

  12. finishRefresh - 准备生命周期管理器,发布ContextRefreshed事件

功能分类:

  • 1.为准备环境
  • 2 3 4 5 6为准备BeanFactionsFactory
  • 7 8 9  10 12为准备ApplicationContext
  • 11为初始化BeanFactory

 

 

1.prepareRefresh

  • 这一步创建和准备了Environment对象,它作为ApplicationContext的一个成员变量
  • Environment对象的作用之一就是为后续的@Value,值注入时提供键值
  • Environment分成三个主要部分

             ① systemProperties - 保存 java 环境键值

             ② systemEnvironment - 保存系统环境键值

             ③ 自定义 PropertySource - 保存自定义键值,例如来自于 *.properties 文件的键值

2. obtainFreshBeanFactory

  • 这一步获取(或创建)BeanFactory,它也是作为ApplicationContext的一个成员变量
  • BeanFactory的作用是负责bean的创建,依赖注入和初始化。bean的各项特征由BeanDefinition定义

                  ①BeanDefinition作为bean的设计蓝图,规定了bean的特征。如单例多例,依赖关系,初始销毁方法等。

                  ②BeanDefinition的来源有多种多样,可以是通过xml获得,配置类获得,组件扫描获得,也可以是编程添加

  • 所有的BeanDefinition会存入BeanFactory中的beanDefinitionMap 集合

3. prepareBeanFactory

  • 这一步会进一步完善BeanFactory,为它的各项成员变量赋值
  • beanExpressionResolver 用来解析 SpEL,常见实现为 StandardBeanExpressionResolver
  • propertyEditorRegistrars 会注册类型转换器  
    • 它在这里使用了 ResourceEditorRegistrar 实现类

    • 并应用 ApplicationContext 提供的 Environment 完成 ${ } 解析

  • registerResolvableDependency 来注册 beanFactory 以及 ApplicationContext,让它们也能用于依赖注入

  • beanPostProcessors 是 bean 后处理器集合,会工作在 bean 的生命周期各个阶段,此处会添加两个
    • ApplicationListenerDetector 用来识别容器中 ApplicationListener 类型的 bean

    • ApplicationContextAwareProcessor 用来解析 Aware 接口

4. postProcessBeanFactory

  • 这一步是空实现,留给子类扩展。

    • 一般 Web 环境的 ApplicationContext 都要利用它注册新的 Scope,完善 Web 下的 BeanFactory

  • 这里体现的是模板方法设计模式

5. invokeBeanFactoryPostProcessors

  • 这一步会调用 beanFactory 后处理器

  • beanFactory 后处理器,充当 beanFactory 的扩展点,可以用来补充或修改 BeanDefinition

  • 常见的 beanFactory 后处理器有

    • ConfigurationClassPostProcessor – 解析 @Configuration、@Bean、@Import、@PropertySource 等

    • PropertySourcesPlaceHolderConfigurer – 替换 BeanDefinition 中的 ${ }

    • MapperScannerConfigurer – 补充 Mapper 接口对应的 BeanDefinition

6. registerBeanPostProcessors

  • 这一步是继续从 beanFactory 中找出 bean 后处理器,添加至 beanPostProcessors 集合中

  • bean 后处理器,充当 bean 的扩展点,可以工作在 bean 的实例化、依赖注入、初始化阶段,常见的有:

    • AutowiredAnnotationBeanPostProcessor 功能有:解析 @Autowired,@Value 注解

    • CommonAnnotationBeanPostProcessor 功能有:解析 @Resource,@PostConstruct,@PreDestroy

    • AnnotationAwareAspectJAutoProxyCreator 功能有:为符合切点的目标 bean 自动创建代理

7. initMessageSource

  • 这一步是为 ApplicationContext 添加 messageSource 成员,实现国际化功能

  • 去 beanFactory 内找名为 messageSource 的 bean,如果没有,则提供空的 MessageSource 实现

8. initApplicationContextEventMulticaster

  • 这一步为 ApplicationContext 添加事件广播器成员,即 applicationContextEventMulticaster

  • 它的作用是发布事件给监听器

  • 去 beanFactory 找名为 applicationEventMulticaster 的 bean 作为事件广播器,若没有,会创建默认的事件广播器

  • 之后就可以调用 ApplicationContext.publishEvent(事件对象) 来发布事件

9. onRefresh

  • 这一步是空实现,留给子类扩展

    • SpringBoot 中的子类在这里准备了 WebServer,即内嵌 web 容器

  • 体现的是模板方法设计模式

 

10. registerListeners

  • 这一步会从多种途径找到事件监听器,并添加至 applicationEventMulticaster

  • 事件监听器顾名思义,用来接收事件广播器发布的事件,有如下来源

    • 事先编程添加的

    • 来自容器中的 bean

    • 来自于 @EventListener 的解析

  • 要实现事件监听器,只需要实现 ApplicationListener 接口,重写其中 onApplicationEvent(E e) 方法即可

11.finishBeanFactoryInitialization

  • 这一步会将 beanFactory 的成员补充完毕,并初始化所有非延迟单例 bean

  • conversionService 也是一套转换机制,作为对 PropertyEditor 的补充

  • embeddedValueResolvers 即内嵌值解析器,用来解析 @Value 中的 ${ },借用的是 Environment 的功能

  • singletonObjects 即单例池,缓存所有单例对象

    • 对象的创建都分三个阶段,每一阶段都有不同的 bean 后处理器参与进来,扩展功能

12. finishRefresh

  • 这一步会为 ApplicationContext 添加 lifecycleProcessor 成员,用来控制容器内需要生命周期管理的 bean

  • 如果容器中有名称为 lifecycleProcessor 的 bean 就用它,否则创建默认的生命周期管理器

  • 准备好生命周期管理器,就可以实现

    • 调用 context 的 start,即可触发所有实现 LifeCycle 接口 bean 的 start

    • 调用 context 的 stop,即可触发所有实现 LifeCycle 接口 bean 的 stop

  • 发布 ContextRefreshed 事件,整个 refresh 执行完成

 

posted @   yxhhhhhh  阅读(67)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
点击右上角即可分享
微信分享提示