spring boot的BeanDefinitionMap初始化过程

1.执行在Initializer中congtext创建BeanDefinitionRegistryPostProcessor#postProcessBeanDefinitionRegistry
2.获取BeanFactory中BeanDefinitionMap的(PriorityOrdered)BeanDefinitionRegistryPostProcessor#postProcessBeanDefinitionRegistry
    处理ConfigurationClassPostProcessor
3.获取BeanFactory中BeanDefinitionMap的(Ordered)BeanDefinitionRegistryPostProcessor#postProcessBeanDefinitionRegistry
4.获取BeanFactory中BeanDefinitionMap的BeanDefinitionRegistryPostProcessor#postProcessBeanDefinitionRegistry
5.统一执行1-4步中的BeanDefinitionRegistryPostProcessor#postProcessBeanFactory
6.统一执行1-4步中的BeanFactoryPostProcessor#postProcessBeanFactory
7.步5和步6执行完可能继续生成剩余未处理的BeanFactoryPostProcessor此时统一按:PriorityOrdered=>Ordered=>普通调用#postProcessBeanFactory
    在PriorityOrdered中存在PropertySourcesPlaceholderConfigurer对于BeanDefinition中字符串${}进行替换
        visitParentName(beanDefinition);
        visitBeanClassName(beanDefinition);
        visitFactoryBeanName(beanDefinition);
        visitFactoryMethodName(beanDefinition);
        visitScope(beanDefinition);
        visitPropertyValues(beanDefinition.getPropertyValues());
        ConstructorArgumentValues cas = beanDefinition.getConstructorArgumentValues();
        visitIndexedArgumentValues(cas.getIndexedArgumentValues());
        visitGenericArgumentValues(cas.getGenericArgumentValues());


ConfigurationClassPostProcessor的postProcessBeanDefinitionRegistry执行过程:
1.parse(Set configCandidates):解析BeanDefinitionHolder
2.BeanDefinition包装为ConfigurationClass
3.processConfigurationClass(ConfigurationClass configClass):解析ConfigurationClass
4.doProcessConfigurationClass(ConfigurationClass configClass, SourceClass sourceClass)
    1:processMemberClasses()解析内部类:存在Configuration则执行步骤3.processConfigurationClass(ConfigurationClass configClass)
    2:解析SourceClass可重复注解@PropertySource,获取value(为文件的位置),并添加ResourcePropertySource到Environment(instanceof ConfigurableEnvironment)
    3.解析SourceClass可重复注解@ComponentScan,通过ClassPathBeanDefinitionScanner扫描文件获取到ScannedGenericBeanDefinition并注册到Registry.BeanDefinitionMap,遍历scannedBeanDefinitions是否为Configuration候选者,是则包装为ConfigurationClass并执行则执行步骤3.processConfigurationClass(ConfigurationClass configClass)
    4.getImports(sourceClass)并解析:@Import中的value值(TODO:涉及到4种情况)
    5.解析注解@ImportResource然后configClass.addImportedResource(resolvedResource, readerClass);
    6.获取sourceClass中@bean方法并configClass.addBeanMethod(new BeanMethod(methodMetadata, configClass));
    7.获取sourceClass所有接口中的默认@bean方法并configClass.addBeanMethod(new BeanMethod(methodMetadata, configClass));
    8.获取sourceClass父类(除去java包下或者排除knownSuperclasses)如果存在则执行步骤4.doProcessConfigurationClass
5.处理延时processDeferredImportSelectors
    1.org.springframework.boot.autoconfigure.EnableAutoConfigurationImportSelector这里面会对META-INF/spring.factories中的EnableAutoConfiguration.class进行配置
6.注册ConfigurationClasses到Registry.BeanDefinitionMap
    1.判断是否shouldSkip(注意Configuration有父子关系,也需要判断)
    2.ConfigurationClass如果是被父亲引入的需要将该注册到BeanDefinitionMap
    3.注册configClass.getBeanMethods(),注册到BeanDefinitionMap
    4.loadBeanDefinitionsFromImportedResources,这里会对资源文件进行判断读取".groovy":GroovyBeanDefinitionReader.class,其他的按XmlBeanDefinitionReader.class读取
    5.loadBeanDefinitionsFromRegistrars调用ImportBeanDefinitionRegistrar#registerBeanDefinitions
7.获取当前BeanDefinitionMap中未处理的Configuration进行执行步骤1parse(Set configCandidates)

通过分析完bean definition如何加载到BeanFactory,我们提出几个问题:
1.@Conditional和@ConfigurationCondition的使用原理 以及两个周期(PARSE_CONFIGURATION,REGISTER_BEAN)
2.@Import的使用原理
Configuration ImportSelector ImportBeanDefinitionRegistrar (regular component)classes
3.如何进行自动配置,AutoConfigurationImportSelector原理
4.什么时候加载PropertySourcesPlaceholderConfigurer
5.@ComponentScan扫描
6.BeanDefinitionRegistryPostProcessor和BeanDefinitionPostProcessor区别

BeanDefinitionRegistryPostProcessor主要bean definition定义 包括BeanDefinitionPostProcessor的定义
BeanDefinitionPostProcessor        主要bean definition处理

7.ApplicationContextInitializer和ApplicationContext区别
8.SpringApplicationRunListeners的生命周期
9.AnnotationMetadata的实现类StandardAnnotationMetadata(基于AnnotatedElementUtils)和AnnotationMetadataReadingVisitor(基于asm实现) asm实现相对较弱只能识别当前类的字节码内容
10.PropertySourcesPropertyResolver的使用原理

        MutablePropertySources propertySources = new MutablePropertySources();
        Map map = new HashMap<>(16);
        map.put("application.name","Test");
        map.put("port","Test");
        map.put("application.port","${port:9080}");
        propertySources.addLast(new MapPropertySource("hello",map));
        PropertySourcesPropertyResolver propertySourcesPropertyResolver = new PropertySourcesPropertyResolver(propertySources);

        String s0 = propertySourcesPropertyResolver.getProperty("application.port");
        String s1 = propertySourcesPropertyResolver.resolvePlaceholders("${application.port}");
        String s2 = propertySourcesPropertyResolver.resolveRequiredPlaceholders("${application.port}");

spring对bean创建过程的扩展
org.springframework.beans.factory.config.InstantiationAwareBeanPostProcessor#postProcessBeforeInstantiation
org.springframework.beans.factory.config.BeanPostProcessor#postProcessAfterInitialization
org.springframework.beans.factory.support.MergedBeanDefinitionPostProcessor#postProcessMergedBeanDefinition
org.springframework.beans.factory.config.SmartInstantiationAwareBeanPostProcessor#determineCandidateConstructors
org.springframework.beans.factory.config.InstantiationAwareBeanPostProcessor#postProcessAfterInstantiation
org.springframework.beans.factory.config.InstantiationAwareBeanPostProcessor#postProcessPropertyValues
    RequiredAnnotationBeanPostProcessor
    AutowiredAnnotationBeanPostProcessor
invokeAwareMethods(BeanNameAware,BeanClassLoaderAware,BeanFactoryAware)
org.springframework.beans.factory.config.BeanPostProcessor#postProcessBeforeInitialization
    ApplicationContextAwareProcessor#invokeAwareInterfaces(EnvironmentAware,ApplicationEventPublisherAware,ApplicationContextAware...)
    InitDestroyAnnotationBeanPostProcessor@PostConstruct
invokeInitMethods=((InitializingBean) bean).afterPropertiesSet();
invokeCustomInitMethod
org.springframework.beans.factory.config.BeanPostProcessor#postProcessAfterInitialization

对于bean实现SmartInitializingSingleton进行处理(如RestTemplate的LoadBalanced)
注意factorybean.getObject后会执行org.springframework.beans.factory.config.BeanPostProcessor#postProcessAfterInitialization
DefaultListableBeanFactory#preInstantiateSingletons初始化单例bean后对SmartInitializingSingleton进行继续加工处理

容器关闭时候:
手动关闭org.springframework.context.support.AbstractApplicationContext#close
外部命令触发:org.springframework.context.ConfigurableApplicationContext#registerShutdownHook
扩展流程:
发布事件ContextClosedEvent
org.springframework.context.LifecycleProcessor#onClose
org.springframework.beans.factory.DisposableBean#destroy
org.springframework.context.support.AbstractApplicationContext#onClose

dependentBeanMap  key:beanName value:依赖beanName的bean
dependenciesForBeanMap key:beanName value:beanName依赖的bean
singletonObjects:
earlySingletonObjects:
singletonFactories:
registeredSingletons:
singletonsCurrentlyInCreation:
alreadyCreated:
mergedBeanDefinitions:
beanDefinitionMap:

org.springframework.beans.factory.support.AbstractBeanDefinition#autowireMode

AUTOWIRE_BY_NAME|AUTOWIRE_BY_TYPE会对bean中的PropertyDescriptor进行分析注入,而@autowire是通过后置处理postProcessPropertyValues进行处理添加到PropertyValues

你可能感兴趣的:(spring boot的BeanDefinitionMap初始化过程)