分享
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
获课 ♥》www.bcwit.top/14840/
一、IoC容器启动的双模式入口
Spring提供了两种核心容器实现:BeanFactory与ApplicationContext。前者是基础容器接口,后者在其基础上扩展了AOP、事件发布等高级功能。两者的启动流程均遵循相同的生命周期模型,但实现细节存在差异。
1. 配置元数据加载
容器启动的第一步是加载配置元数据。Spring支持XML、注解、Java配置类三种元数据格式,其底层通过BeanDefinitionReader接口实现统一解析:
XML解析:XmlBeanDefinitionReader利用SAX解析器读取XML文件,将<bean>标签转换为BeanDefinition对象。
注解扫描:ClassPathBeanDefinitionScanner通过ASM字节码框架扫描类路径,识别@Component及其派生注解。
Java配置解析:ConfigurationClassBeanDefinitionReader处理@Configuration类,解析@Bean方法定义。
2. 容器初始化阶段划分
Spring将容器初始化过程划分为两个阶段:
容器初始化阶段:完成配置解析、Bean定义注册,不涉及Bean实例化。
Bean初始化阶段:执行Bean的实例化、依赖注入、初始化方法调用。
二、核心启动流程的五重奏
IoC容器的启动流程可拆解为五个关键步骤,每个步骤均涉及多个扩展点的协同工作。
1. 准备阶段:刷新前的预处理
在refresh()方法入口,Spring会执行以下操作:
初始化属性源(PropertySourcesPlaceholderConfigurer)
验证必需属性(如Environment中的关键配置)
触发ApplicationContextInitializer初始化器(常用于配置文件加载)
2. Bean定义加载阶段
通过invokeBeanFactoryPostProcessors()方法触发两类处理器:
BeanFactoryPostProcessor:修改已注册的Bean定义(如PropertySourcesPlaceholderConfigurer替换属性占位符)。
BeanDefinitionRegistryPostProcessor:动态注册新的Bean定义(如@ComponentScan扫描结果)。
3. Bean实例化前准备
在finishBeanFactoryInitialization()前,Spring会:
注册Bean后置处理器(BeanPostProcessor),如AutowiredAnnotationBeanPostProcessor处理@Autowired注入。
初始化国际化消息源(MessageSource)。
注册事件监听器(ApplicationListener)。
4. Bean实例化阶段
该阶段通过getBean()方法触发三级缓存机制:
单例池(singletonObjects):存储完全初始化的Bean实例。
早期暴露对象(earlySingletonObjects):解决循环依赖时暂存未完全初始化的Bean。
单例工厂(singletonFactories):存储ObjectFactory,用于延迟创建Bean。
5. 容器就绪阶段
当所有Bean初始化完成后,Spring会:
发布ContextRefreshedEvent事件。
执行@PostConstruct注解方法和InitializingBean接口方法。
启动定时任务调度器(TaskExecutor)。
三、关键扩展点深度解析
Spring IoC容器的扩展性源于其精心设计的扩展点,开发者可通过实现特定接口干预启动流程。
1. BeanFactoryPostProcessor:定义层面的修改
典型应用场景:
PropertySourcesPlaceholderConfigurer:解析${}属性占位符。
ConfigurationClassPostProcessor:处理@Configuration类。
自定义元数据增强:通过实现接口修改Bean作用域、懒加载等属性。
2. BeanPostProcessor:实例层面的干预
核心后置处理器:
CommonAnnotationBeanPostProcessor:处理@PostConstruct和@PreDestroy。
AutowiredAnnotationBeanPostProcessor:实现@Autowired和@Value注入。
AopAutoProxyCreator:生成AOP代理对象。
3. FactoryBean:工厂模式的应用
FactoryBean接口允许开发者自定义Bean的创建逻辑,常用于集成第三方组件(如MyBatis的SqlSessionFactoryBean)。
四、启动流程的优化实践
理解IoC容器启动流程后,可针对性地进行性能调优和问题排查。
1. 启动加速策略
延迟加载:通过@Lazy注解或XML配置延迟初始化非关键Bean。
并行解析:Spring Boot 2.x支持并行加载配置类(需配置spring.main.lazy-initialization=true)。
缓存优化:启用@Configuration类的CGLIB代理(spring.aop.proxy-target-class=true)减少重复解析。
2. 常见问题定位
Bean创建异常:检查BeanCurrentlyInCreationException判断循环依赖。
属性注入失败:通过NoSuchBeanDefinitionException确认Bean作用域和依赖关系。
启动卡顿:使用-Ddebug参数输出详细启动日志,定位耗时操作。
五、架构设计思想启示
Spring IoC容器的设计蕴含着软件工程的经典智慧:
控制反转:通过容器管理依赖,降低组件耦合度。
模板方法模式:AbstractApplicationContext定义算法骨架,子类实现具体步骤。
观察者模式:通过事件发布机制实现组件解耦。
策略模式:通过BeanPostProcessor实现扩展点的灵活组合。
有疑问加站长微信联系(非本文作者))
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信451 次点击
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传