xml中的信息大多都是被最终解析为bean定义注册到spring容器中
大体过程在spring容器,刷新beanFactory时【obtainFreshBeanFactory()方法】,会解析xml配置文件(beanDefinitionReader)注册所有可加载beanDefinition 如下流程:
beanDefinitionReader->命名空间解析器NamespaceHandlerResolver->通过xml头部的命名空间得到相应标签的bean定义解析器BeanDefinitionParser->将解析得到的beanDefinition注册进容器
扫描注入bean
在spring容器,执行beanFactory后置处理器时【invokeBeanFactoryPostProcessors(beanFactory)方法】,会扫描(beanDefinitionScaner)指定包class来加载beanDefinition如下流程:
BeanDefinitionScaner一般是有@EnableXxx或自动装配-->@Import(XxxImportBeanDefinitionRegistrar)-->之后要么直接在Registrar直接进行扫描解析将beanDefinition注册进去,要么注入一个BeanDefinitionRegistryPostProcessor之后再这里面实现扫描注入
大家可以通过调试dubbo的两种配置方式来观察整个过程(一种直接spring的xml配置,一种@EnableDubbo+服务提供消费注解)