摘要
在前面的文章https://goo.gl/d5SR9t中我们介绍过基于Spring的Schema扩展,实际上就是自定义一些XML标签,通过实现Sring的一些接口解析这些标签,然后在Spring容器启动的时候可以自动调用解析过程,生成bean或者做其他操作,Dubbo中bean的生成过程也是依照这样的原理。
dubbo中自定义Schema及解析
Dubbo中自定义的标签及解析过程实现都在dubbo-config-spring这个包中。
Schema配置
下面是META-INF下的sping.handlers和spring.schemas两个文件的内容:
spring.handlers:
http\://code.alibabatech.com/schema/dubbo=com.alibaba.dubbo.config.spring.schema.DubboNamespaceHandler
spring.schemas:
http\://code.alibabatech.com/schema/dubbo/dubbo.xsd=META-INF/dubbo.xsd
schema解析
查看spring.handlers配置中的DubboNamespaceHandler类可以看到如下的代码:
public class DubboNamespaceHandler extends NamespaceHandlerSupport {
static {
Version.checkDuplicate(DubboNamespaceHandler.class);
}
public void init() {
registerBeanDefinitionParser("application", new DubboBeanDefinitionParser(ApplicationConfig.class, true));
registerBeanDefinitionParser("module",